jcs's openbsd hax
openbsd
at jcs 83 lines 2.8 kB view raw
1.\" $OpenBSD: pidfile.3,v 1.8 2025/06/06 22:01:40 schwarze Exp $ 2.\" $NetBSD: pidfile.3,v 1.2 2001/04/12 22:34:31 sommerfeld Exp $ 3.\" 4.\" Copyright (c) 1999 The NetBSD Foundation, Inc. 5.\" All rights reserved. 6.\" 7.\" This code is derived from software contributed to The NetBSD Foundation 8.\" by Jason R. Thorpe. 9.\" 10.\" Redistribution and use in source and binary forms, with or without 11.\" modification, are permitted provided that the following conditions 12.\" are met: 13.\" 1. Redistributions of source code must retain the above copyright 14.\" notice, this list of conditions and the following disclaimer. 15.\" 2. Redistributions in binary form must reproduce the above copyright 16.\" notice, this list of conditions and the following disclaimer in the 17.\" documentation and/or other materials provided with the distribution. 18.\" 19.\" THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 20.\" ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 21.\" TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 22.\" PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 23.\" BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 24.\" CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 25.\" SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 26.\" INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 27.\" CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 28.\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 29.\" POSSIBILITY OF SUCH DAMAGE. 30.\" 31.Dd $Mdocdate: June 6 2025 $ 32.Dt PIDFILE 3 33.Os 34.Sh NAME 35.Nm pidfile 36.Nd write a daemon pid file 37.Sh SYNOPSIS 38.Lb libutil 39.In util.h 40.Ft int 41.Fn pidfile "const char *basename" 42.Sh DESCRIPTION 43.Fn pidfile 44writes a file containing the process ID of the program to the 45.Pa /var/run 46directory. 47The file name has the form 48.Pa /var/run/basename.pid . 49If the 50.Ar basename 51argument is NULL, 52.Nm 53will determine the program name and use that instead. 54.Pp 55The pid file can be used as a quick reference if 56the process needs to be sent a signal. 57When the program exits, the pid file will be removed automatically, 58unless the program receives a fatal signal. 59.Sh RETURN VALUES 60.Fn pidfile 61returns 0 on success and -1 on failure. 62.Sh SEE ALSO 63.Xr atexit 3 64.Sh HISTORY 65The 66.Nm 67function call appeared in 68.Ox 3.0 . 69.Sh CAVEATS 70If 71.Fn pidfile 72is called multiple times with different 73.Ar basename , 74only the last pidfile will be removed upon exit. 75.Pp 76.Fn pidfile 77uses 78.Fn atexit 79to ensure the pidfile is unlinked at program exit. 80However, programs that use the 81.Fn _exit 82function (for example, in signal handlers) 83will not trigger this behaviour.