mirror of
				https://gitlab.freedesktop.org/libbsd/libbsd.git
				synced 2025-10-20 22:31:34 +02:00 
			
		
		
		
	Compare commits
	
		
			156 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 4663364783 | ||
|   | df5aebd7e1 | ||
|   | 9587882316 | ||
|   | 01f146c28e | ||
|   | 509841b533 | ||
|   | 06f0585c48 | ||
|   | 7c4caa679a | ||
|   | 30349f8922 | ||
|   | 96a2dae352 | ||
|   | a4812cdf24 | ||
|   | d3a09e1cf4 | ||
|   | 330b569fe3 | ||
|   | 8c26c40ad2 | ||
|   | e9933255d4 | ||
|   | c984dacd65 | ||
|   | 35785f8dd1 | ||
|   | 2a0260d08c | ||
|   | f8d52ead5e | ||
|   | cf683a275a | ||
|   | 7196b4dcca | ||
|   | a97ce513e0 | ||
|   | ee0489eb2b | ||
|   | cb7bc0d85e | ||
|   | 1be0bdb2c9 | ||
|   | ff0d700df0 | ||
|   | 3862764872 | ||
|   | 918a4dba4a | ||
|   | 444bd1fbb8 | ||
|   | 1d69ae1cd5 | ||
|   | 14524b545d | ||
|   | c21d788fea | ||
|   | fdcae57707 | ||
|   | e9e4a60d7e | ||
|   | 309c82a016 | ||
|   | cd67cb1417 | ||
|   | 1b5b1cd52a | ||
|   | ddefaae330 | ||
|   | e7f3976088 | ||
|   | e59ac2c96c | ||
|   | 7cfa7e4304 | ||
|   | 7620fef70b | ||
|   | 08139dd50e | ||
|   | d90ce079f7 | ||
|   | c1d086c224 | ||
|   | e37293a18a | ||
|   | 34bf1068a2 | ||
|   | 4eab0cc351 | ||
|   | 752997462a | ||
|   | d5d9186937 | ||
|   | f8e8063079 | ||
|   | 786d143920 | ||
|   | 866f73af91 | ||
|   | f71d8e0501 | ||
|   | 0b96e1a218 | ||
|   | 109cafb393 | ||
|   | 6434858314 | ||
|   | 943939d0e5 | ||
|   | 3d614131b5 | ||
|   | 8723226040 | ||
|   | b5cc17d664 | ||
|   | abf14c3940 | ||
|   | 23973e2221 | ||
|   | 980f04f77b | ||
|   | 8d2f12d7f0 | ||
|   | 88004b30ff | ||
|   | dcaa93d984 | ||
|   | 0aa777f47e | ||
|   | 540ab03b18 | ||
|   | 93321224f6 | ||
|   | 2fb7200d45 | ||
|   | 0acd86f6eb | ||
|   | 901ed630fc | ||
|   | 059f89ca95 | ||
|   | 4a6303ba3b | ||
|   | 7446f029b5 | ||
|   | e80d338b18 | ||
|   | b891772ad6 | ||
|   | b0eb19970a | ||
|   | 0bf3d3913f | ||
|   | 913cdd91b1 | ||
|   | 200eeb1265 | ||
|   | fbd622971d | ||
|   | 755d86be01 | ||
|   | cd4996cebe | ||
|   | a7dd4457f5 | ||
|   | 8be40010ce | ||
|   | e1f2a6f869 | ||
|   | 87dd203c26 | ||
|   | de2062873f | ||
|   | 71e5db4cde | ||
|   | 9d04217174 | ||
|   | 17a9a8472e | ||
|   | 94fe901eda | ||
|   | 28585a58bd | ||
|   | b36c59c0ed | ||
|   | 8b6a74775b | ||
|   | c594192bac | ||
|   | 8478e57463 | ||
|   | f7caf2b30d | ||
|   | 520682e596 | ||
|   | 4c01261f39 | ||
|   | 8a99226f16 | ||
|   | 1497d34760 | ||
|   | 741eb58763 | ||
|   | 9baf9640b9 | ||
|   | 4b95e82a32 | ||
|   | c766e58acf | ||
|   | be6ab54986 | ||
|   | 5b19adfa82 | ||
|   | acb7c42d7c | ||
|   | 06a60a166a | ||
|   | 51863b6cf9 | ||
|   | 08afd5d4c9 | ||
|   | 1f0b0b23cd | ||
|   | 32d79b0310 | ||
|   | cd730a02c3 | ||
|   | 11f2c32df2 | ||
|   | 30c794083f | ||
|   | ddebbd6792 | ||
|   | abe0a4a7e6 | ||
|   | 2872bfa151 | ||
|   | e544a41f62 | ||
|   | 7b3873bc1e | ||
|   | 8103fe1486 | ||
|   | d63e081303 | ||
|   | 3fed78e5b0 | ||
|   | 2a81893cc0 | ||
|   | 98a2479f0b | ||
|   | 57cc5326cf | ||
|   | 9e4adc4633 | ||
|   | db406fe24c | ||
|   | 9396cc62cf | ||
|   | 7a70f1b019 | ||
|   | ca28f28046 | ||
|   | dd2756e000 | ||
|   | 3c9182b85e | ||
|   | 4d17a18db5 | ||
|   | 7da57b293f | ||
|   | 254808d9ef | ||
|   | 183cc3cbf1 | ||
|   | c17c7e13c3 | ||
|   | a5dbef45e7 | ||
|   | 27842d7f77 | ||
|   | c5398adfe2 | ||
|   | 538bc87998 | ||
|   | 04250f6a7c | ||
|   | 5c078ce2f5 | ||
|   | 614eb0402a | ||
|   | b6e8469059 | ||
|   | d3e14ea99e | ||
|   | e51be45c40 | ||
|   | 56ddcfe65a | ||
|   | 1bf8b96ac8 | ||
|   | 16e6ac99fe | ||
|   | 56f2e55b7a | ||
|   | 5ac14531b5 | 
							
								
								
									
										15
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										15
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -1,6 +1,19 @@ | ||||
| ChangeLog | ||||
| libbsd.pc | ||||
| *.pc | ||||
| *.la | ||||
| *.lo | ||||
| *.o | ||||
| *.so* | ||||
| *.a | ||||
| .deps/ | ||||
| .libs/ | ||||
| Makefile | ||||
| Makefile.in | ||||
| aclocal.m4 | ||||
| autom4te.cache/ | ||||
| build-aux/ | ||||
| configure | ||||
| config.* | ||||
| libtool | ||||
| m4/ | ||||
| stamp-h1 | ||||
|   | ||||
							
								
								
									
										478
									
								
								COPYING
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										478
									
								
								COPYING
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,478 @@ | ||||
| The following 4-clause BSD licenses are only for man pages, specifically | ||||
| for man/arc4random.3, man/tree.3 and man/getprogname.3. | ||||
|  | ||||
|  | ||||
|     Copyright 1997 Niels Provos <provos@physnet.uni-hamburg.de> | ||||
|     All rights reserved. | ||||
|  | ||||
|     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. All advertising materials mentioning features or use of this software | ||||
|        must display the following acknowledgement: | ||||
|          This product includes software developed by Niels Provos. | ||||
|     4. 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 BY THE AUTHOR ``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. | ||||
|  | ||||
|     -- | ||||
|  | ||||
|     Copyright © 2001 Christopher G. Demetriou | ||||
|     All rights reserved. | ||||
|  | ||||
|     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. All advertising materials mentioning features or use of this software | ||||
|        must display the following acknowledgement: | ||||
|              This product includes software developed for the | ||||
|              NetBSD Project.  See http://www.netbsd.org/ for | ||||
|              information about NetBSD. | ||||
|     4. 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 BY THE AUTHOR ``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. | ||||
|  | ||||
|  | ||||
| The rest of the licenses apply to code and/or man pages. | ||||
|  | ||||
|  | ||||
|     Copyright © 2004-2006, 2008-2012 Guillem Jover <guillem@hadrons.org> | ||||
|     Copyright © 2005 Hector Garcia Alvarez | ||||
|     Copyright © 2005 Aurelien Jarno | ||||
|     Copyright © 2006 Robert Millan | ||||
|  | ||||
|     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. | ||||
|  | ||||
|     -- | ||||
|  | ||||
|     Copyright © 1980, 1982, 1986, 1989-1994 | ||||
| 	The Regents of the University of California.  All rights reserved. | ||||
|     Copyright © 2001 Mike Barcroft <mike@FreeBSD.org> | ||||
|  | ||||
|     Some code is derived from software contributed to Berkeley by | ||||
|     the American National Standards Committee X3, on Information | ||||
|     Processing Systems. | ||||
|  | ||||
|     Some code is derived from software contributed to Berkeley by | ||||
|     Peter McIlroy. | ||||
|  | ||||
|     Some code is derived from software contributed to Berkeley by | ||||
|     Ronnie Kon at Mindcraft Inc., Kevin Lew and Elmer Yglesias. | ||||
|  | ||||
|     Some code is derived from software contributed to Berkeley by | ||||
|     Dave Borman at Cray Research, Inc. | ||||
|  | ||||
|     Some code is derived from software contributed to Berkeley by | ||||
|     Paul Vixie. | ||||
|  | ||||
|     Some code is derived from software contributed to Berkeley by | ||||
|     Chris Torek. | ||||
|  | ||||
|     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. Neither the name of the University nor the names of its contributors | ||||
|        may be used to endorse or promote products derived from this software | ||||
|        without specific prior written permission. | ||||
|  | ||||
|     THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``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 REGENTS OR CONTRIBUTORS 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. | ||||
|  | ||||
|     -- | ||||
|  | ||||
|     Copyright © 1996  Peter Wemm <peter@FreeBSD.org>. | ||||
|     All rights reserved. | ||||
|     Copyright © 2002 Networks Associates Technology, Inc. | ||||
|     All rights reserved. | ||||
|  | ||||
|     Portions of this software were developed for the FreeBSD Project by | ||||
|     ThinkSec AS and NAI Labs, the Security Research Division of Network | ||||
|     Associates, Inc.  under DARPA/SPAWAR contract N66001-01-C-8035 | ||||
|     ("CBOSS"), as part of the DARPA CHATS research program. | ||||
|  | ||||
|     Redistribution and use in source and binary forms, with or without | ||||
|     modification, is 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 BY THE AUTHOR AND CONTRIBUTORS ``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 OR CONTRIBUTORS 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. | ||||
|  | ||||
|     -- | ||||
|  | ||||
|     Copyright © 1995 Peter Wemm <peter@FreeBSD.org> | ||||
|     All rights reserved. | ||||
|  | ||||
|     Redistribution and use in source and binary forms, with or without | ||||
|     modification, is permitted provided that the following conditions | ||||
|     are met: | ||||
|     1. Redistributions of source code must retain the above copyright | ||||
|        notice immediately at the beginning of the file, without modification, | ||||
|        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. This work was done expressly for inclusion into FreeBSD.  Other use | ||||
|        is permitted provided this notation is included. | ||||
|     4. Absolutely no warranty of function or purpose is made by the author | ||||
|        Peter Wemm. | ||||
|     5. Modifications may be freely made to this file providing the above | ||||
|        conditions are met. | ||||
|  | ||||
|     -- | ||||
|  | ||||
|     Copyright © 1997-2000, 2002, 2008 The NetBSD Foundation, Inc. | ||||
|     All rights reserved. | ||||
|  | ||||
|     Some code was contributed to The NetBSD Foundation by Allen Briggs. | ||||
|  | ||||
|     Some code is derived from software contributed to The NetBSD Foundation | ||||
|     by Jason R. Thorpe of the Numerical Aerospace Simulation Facility, | ||||
|     NASA Ames Research Center, by Luke Mewburn and by Tomas Svensson. | ||||
|  | ||||
|     Some code is derived from software contributed to The NetBSD Foundation | ||||
|     by Julio M. Merino Vidal, developed as part of Google's Summer of Code | ||||
|     2005 program. | ||||
|  | ||||
|     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. | ||||
|  | ||||
|     THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS | ||||
|     ``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 FOUNDATION OR CONTRIBUTORS | ||||
|     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. | ||||
|  | ||||
|     -- | ||||
|  | ||||
|     Copyright © 1998, M. Warner Losh <imp@freebsd.org> | ||||
|     All rights reserved. | ||||
|  | ||||
|     Copyright © 2001 Dima Dorfman. | ||||
|     All rights reserved. | ||||
|  | ||||
|     Copyright © 2002 Thomas Moestl <tmm@FreeBSD.org> | ||||
|     All rights reserved. | ||||
|  | ||||
|     Copyright © 2005 Pawel Jakub Dawidek <pjd@FreeBSD.org> | ||||
|     All rights reserved. | ||||
|  | ||||
|     Copyright © 2007 Eric Anderson <anderson@FreeBSD.org> | ||||
|     Copyright © 2007 Pawel Jakub Dawidek <pjd@FreeBSD.org> | ||||
|     All rights reserved. | ||||
|  | ||||
|     Copyright © 2007 Dag-Erling Coïdan Smørgrav | ||||
|     All rights reserved. | ||||
|  | ||||
|     Copyright © 2009 Advanced Computing Technologies LLC | ||||
|     Written by: John H. Baldwin <jhb@FreeBSD.org> | ||||
|     All rights reserved. | ||||
|  | ||||
|     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. | ||||
|  | ||||
|     THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``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 OR CONTRIBUTORS 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. | ||||
|  | ||||
|     -- | ||||
|  | ||||
|     Copyright © 1997 Christos Zoulas. | ||||
|     All rights reserved. | ||||
|  | ||||
|     Copyright © 2002 Niels Provos <provos@citi.umich.edu> | ||||
|     All rights reserved. | ||||
|  | ||||
|     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. | ||||
|  | ||||
|     THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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. | ||||
|  | ||||
|     -- | ||||
|  | ||||
|     Copyright © 2007 Dag-Erling Coïdan Smørgrav | ||||
|     All rights reserved. | ||||
|  | ||||
|     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 | ||||
|        in this position and unchanged. | ||||
|     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. | ||||
|  | ||||
|     THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``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 OR CONTRIBUTORS 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. | ||||
|  | ||||
|     -- | ||||
|  | ||||
|     Copyright © 1998, 2000 Todd C. Miller <Todd.Miller@courtesan.com> | ||||
|     Copyright © 2004 Ted Unangst | ||||
|  | ||||
|     Copyright © 2004 Ted Unangst and Todd Miller | ||||
|     All rights reserved. | ||||
|  | ||||
|     Permission to use, copy, modify, and distribute this software for any | ||||
|     purpose with or without fee is hereby granted, provided that the above | ||||
|     copyright notice and this permission notice appear in all copies. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | ||||
|     WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | ||||
|     MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | ||||
|     ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | ||||
|     WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | ||||
|     ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF | ||||
|     OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||||
|  | ||||
|     -- | ||||
|  | ||||
|     Copyright © 2000-2002, 2004-2005, 2007, 2010 | ||||
|         Todd C. Miller <Todd.Miller@courtesan.com> | ||||
|  | ||||
|     Permission to use, copy, modify, and distribute this software for any | ||||
|     purpose with or without fee is hereby granted, provided that the above | ||||
|     copyright notice and this permission notice appear in all copies. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | ||||
|     WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | ||||
|     MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | ||||
|     ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | ||||
|     WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | ||||
|     ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF | ||||
|     OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||||
|  | ||||
|     Sponsored in part by the Defense Advanced Research Projects | ||||
|     Agency (DARPA) and Air Force Research Laboratory, Air Force | ||||
|     Materiel Command, USAF, under agreement number F39502-99-1-0512 | ||||
|  | ||||
|     -- | ||||
|  | ||||
|     Copyright © 1996 by Internet Software Consortium. | ||||
|  | ||||
|     Permission to use, copy, modify, and distribute this software for any | ||||
|     purpose with or without fee is hereby granted, provided that the above | ||||
|     copyright notice and this permission notice appear in all copies. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS" AND INTERNET SOFTWARE CONSORTIUM DISCLAIMS | ||||
|     ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES | ||||
|     OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL INTERNET SOFTWARE | ||||
|     CONSORTIUM BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL | ||||
|     DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR | ||||
|     PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS | ||||
|     ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS | ||||
|     SOFTWARE. | ||||
|  | ||||
|     -- | ||||
|  | ||||
|     Copyright © 1996, David Mazieres <dm@uun.org> | ||||
|     Copyright © 2008, Damien Miller <djm@openbsd.org> | ||||
|  | ||||
|     Permission to use, copy, modify, and distribute this software for any | ||||
|     purpose with or without fee is hereby granted, provided that the above | ||||
|     copyright notice and this permission notice appear in all copies. | ||||
|  | ||||
|     Modification and redistribution in source and binary forms is | ||||
|     permitted provided that due credit is given to the author and the | ||||
|     OpenBSD project (for instance by leaving this copyright notice | ||||
|     intact). | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | ||||
|     WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | ||||
|     MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | ||||
|     ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | ||||
|     WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | ||||
|     ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF | ||||
|     OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||||
|  | ||||
|     This code is derived from section 17.1 of Applied Cryptography, | ||||
|     second edition, which describes a stream cipher allegedly | ||||
|     compatible with RSA Labs "RC4" cipher (the actual description of | ||||
|     which is a trade secret).  The same algorithm is used as a stream | ||||
|     cipher called "arcfour" in Tatu Ylonen's ssh package. | ||||
|  | ||||
|     Here the stream cipher has been modified always to include the time | ||||
|     when initializing the state.  That makes it impossible to | ||||
|     regenerate the same random sequence twice, so this can't be used | ||||
|     for encryption, but will generate good random numbers. | ||||
|  | ||||
|     RC4 is a registered trademark of RSA Laboratories. | ||||
|  | ||||
|     -- | ||||
|  | ||||
|     Copyright © 2010 William Ahern | ||||
|     Copyright © 2012 Guillem Jover <guillem@hadrons.org> | ||||
|  | ||||
|     Permission is hereby granted, free of charge, to any person obtaining a | ||||
|     copy of this software and associated documentation files (the | ||||
|     "Software"), to deal in the Software without restriction, including | ||||
|     without limitation the rights to use, copy, modify, merge, publish, | ||||
|     distribute, sublicense, and/or sell copies of the Software, and to permit | ||||
|     persons to whom the Software is furnished to do so, subject to the | ||||
|     following conditions: | ||||
|  | ||||
|     The above copyright notice and this permission notice shall be included | ||||
|     in all copies or substantial portions of the Software. | ||||
|  | ||||
|     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS | ||||
|     OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF | ||||
|     MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN | ||||
|     NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, | ||||
|     DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR | ||||
|     OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE | ||||
|     USE OR OTHER DEALINGS IN THE SOFTWARE. | ||||
|  | ||||
|     -- | ||||
|  | ||||
|     This code implements the MD5 message-digest algorithm. | ||||
|     The algorithm is due to Ron Rivest. This code was | ||||
|     written by Colin Plumb in 1993, no copyright is claimed. | ||||
|     This code is in the public domain; do with it what you wish. | ||||
|  | ||||
|     Equivalent code is available from RSA Data Security, Inc. | ||||
|     This code has been tested against that, and is equivalent, | ||||
|     except that you don't need to include two pages of legalese | ||||
|     with every copy. | ||||
|  | ||||
|     To compute the message digest of a chunk of bytes, declare an | ||||
|     MD5Context structure, pass it to MD5Init, call MD5Update as | ||||
|     needed on buffers full of bytes, and then call MD5Final, which | ||||
|     will fill a supplied 16-byte array with the digest. | ||||
|  | ||||
|     -- | ||||
|  | ||||
|     "THE BEER-WARE LICENSE" (Revision 42): | ||||
|     <phk@login.dkuug.dk> wrote this file.  As long as you retain this notice you | ||||
|     can do whatever you want with this stuff. If we meet some day, and you think | ||||
|     this stuff is worth it, you can buy me a beer in return.   Poul-Henning Kamp | ||||
							
								
								
									
										177
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										177
									
								
								Makefile
									
									
									
									
									
								
							| @@ -1,177 +0,0 @@ | ||||
| LIB_NAME := libbsd | ||||
| LIB_VERSION_MAJOR := 0 | ||||
| LIB_VERSION_MINOR := 1 | ||||
| LIB_VERSION_MICRO := 5 | ||||
| LIB_VERSION := $(LIB_VERSION_MAJOR).$(LIB_VERSION_MINOR).$(LIB_VERSION_MICRO) | ||||
|  | ||||
| LIB_PKGCONFIG := $(LIB_NAME).pc | ||||
| LIB_STATIC := $(LIB_NAME).a | ||||
| LIB_SHARED_SO := $(LIB_NAME).so | ||||
| LIB_SONAME := $(LIB_SHARED_SO).$(LIB_VERSION_MAJOR) | ||||
| LIB_SHARED := $(LIB_SONAME).$(LIB_VERSION_MINOR).$(LIB_VERSION_MICRO) | ||||
|  | ||||
| TAR_NAME := $(LIB_NAME)-$(LIB_VERSION) | ||||
| TAR_FILE := $(TAR_NAME).tar.gz | ||||
|  | ||||
| LIB_DIST := \ | ||||
| 	Makefile \ | ||||
| 	README \ | ||||
| 	ChangeLog \ | ||||
| 	Versions \ | ||||
| 	$(LIB_PKGCONFIG).in | ||||
|  | ||||
| LIB_SRCS := \ | ||||
| 	arc4random.c \ | ||||
| 	bsd_getopt.c \ | ||||
| 	err.c \ | ||||
| 	fgetln.c \ | ||||
| 	heapsort.c \ | ||||
| 	humanize_number.c \ | ||||
| 	inet_net_pton.c \ | ||||
| 	hash/md5.c hash/md5hl.c \ | ||||
| 	setmode.c \ | ||||
| 	strmode.c \ | ||||
| 	strlcat.c strlcpy.c \ | ||||
| 	fmtcheck.c \ | ||||
| 	nlist.c \ | ||||
| 	progname.c \ | ||||
| 	vis.c unvis.c | ||||
| LIB_SRCS := $(patsubst %,src/%,$(LIB_SRCS)) | ||||
|  | ||||
| LIB_GEN_SRCS := \ | ||||
| 	man/md5.3bsd \ | ||||
| 	src/hash/md5hl.c | ||||
|  | ||||
| LIB_INCLUDES := \ | ||||
| 	bsd/err.h \ | ||||
| 	bsd/getopt.h \ | ||||
| 	bsd/inet.h \ | ||||
| 	bsd/ip_icmp.h \ | ||||
| 	bsd/random.h \ | ||||
| 	bsd/queue.h \ | ||||
| 	bsd/md5.h \ | ||||
| 	bsd/string.h \ | ||||
| 	bsd/bsd.h \ | ||||
| 	bsd/cdefs.h \ | ||||
| 	bsd/stdlib.h \ | ||||
| 	nlist.h \ | ||||
| 	vis.h \ | ||||
| 	libutil.h | ||||
|  | ||||
| LIB_MANS := \ | ||||
| 	arc4random.3 \ | ||||
| 	arc4random_addrandom.3 \ | ||||
| 	arc4random_stir.3 \ | ||||
| 	strlcpy.3 \ | ||||
| 	strlcat.3 \ | ||||
| 	fgetln.3 \ | ||||
| 	humanize_number.3 \ | ||||
| 	fmtcheck.3 \ | ||||
| 	nlist.3 \ | ||||
| 	setmode.3 \ | ||||
| 	getmode.3 \ | ||||
| 	strmode.3 \ | ||||
| 	md5.3bsd | ||||
| LIB_MANS := $(patsubst %,man/%,$(LIB_MANS)) | ||||
|  | ||||
| LIB_STATIC_OBJS := $(LIB_SRCS:%.c=%.o) | ||||
| LIB_SHARED_OBJS := $(LIB_SRCS:%.c=%.lo) | ||||
|  | ||||
| # Set default value for compilation | ||||
| CFLAGS ?= -g -Wall -Wextra -Wno-unused-variable | ||||
|  | ||||
| MK_CFLAGS := -Iinclude/ -include bsd/bsd.h -D_GNU_SOURCE -D__REENTRANT | ||||
|  | ||||
| prefix		= /usr | ||||
| exec_prefix	= | ||||
| libdir		= ${exec_prefix}/lib | ||||
| usrlibdir	= ${prefix}/lib | ||||
| includedir	= ${prefix}/include | ||||
| pkgconfigdir	= ${usrlibdir}/pkgconfig | ||||
| mandir		= ${prefix}/share/man | ||||
|  | ||||
| .PHONY: libs | ||||
| libs: $(LIB_STATIC) $(LIB_SHARED_SO) $(LIB_PKGCONFIG) | ||||
|  | ||||
| .PHONY: man | ||||
| man: $(LIB_MANS) | ||||
|  | ||||
| %.lo: %.c | ||||
| 	$(CC) -o $@ $(MK_CFLAGS) $(CFLAGS) -DPIC -fPIC -c $< | ||||
|  | ||||
| %.o: %.c | ||||
| 	$(CC) -o $@ $(MK_CFLAGS) $(CFLAGS) -c $< | ||||
|  | ||||
| man/md5.3bsd:  man/mdX.3 | ||||
| 	sed -e 's/mdX/md5/g' -e 's/mdY/md4/g' -e 's/MDX/MD5/g' $< > $@ | ||||
|  | ||||
| src/hash/md5hl.c: src/hash/helper.c | ||||
| 	sed -e 's:hashinc:bsd/md5.h:g' -e 's:HASH:MD5:g' $< > $@ | ||||
|  | ||||
| $(LIB_PKGCONFIG): $(LIB_PKGCONFIG).in | ||||
| 	sed -e 's:@VERSION@:$(LIB_VERSION):' \ | ||||
| 	    -e 's:@prefix@:$(value prefix):' \ | ||||
| 	    -e 's:@exec_prefix@:$(value exec_prefix):' \ | ||||
| 	    -e 's:@libdir@:$(value usrlibdir):' \ | ||||
| 	    -e 's:@includedir@:$(value includedir):' \ | ||||
| 	    $< > $@ | ||||
|  | ||||
| $(LIB_STATIC): $(LIB_STATIC_OBJS) | ||||
| 	ar rcs $@ $^ | ||||
|  | ||||
| $(LIB_SHARED_SO): $(LIB_SONAME) | ||||
| 	ln -fs $^ $@ | ||||
|  | ||||
| $(LIB_SONAME): $(LIB_SHARED) | ||||
| 	ln -fs $^ $@ | ||||
|  | ||||
| $(LIB_SHARED): $(LIB_SHARED_OBJS) | ||||
| 	gcc -shared \ | ||||
| 	  -Wl,-soname -Wl,$(LIB_SONAME) \ | ||||
| 	  -Wl,--version-script=Versions \ | ||||
| 	  -o $@ $^ | ||||
|  | ||||
| .PHONY: ChangeLog | ||||
| ChangeLog: | ||||
| 	-git log --stat -C >$@ | ||||
|  | ||||
| .PHONY: dist | ||||
| dist: ChangeLog | ||||
| 	mkdir $(TAR_NAME) | ||||
| 	cp -a include src man $(LIB_DIST) $(TAR_NAME) | ||||
| 	tar czf $(TAR_FILE) --exclude=.gitignore $(TAR_NAME) | ||||
| 	rm -rf $(TAR_NAME) | ||||
| 	gpg -a -b $(TAR_FILE) | ||||
|  | ||||
| .PHONY: install | ||||
| install: libs man | ||||
| 	mkdir -p $(DESTDIR)/$(libdir) | ||||
| 	mkdir -p $(DESTDIR)/$(usrlibdir) | ||||
| 	mkdir -p $(DESTDIR)/$(includedir)/bsd/ | ||||
| 	mkdir -p $(DESTDIR)/$(mandir)/man3 | ||||
| 	mkdir -p $(DESTDIR)/$(pkgconfigdir) | ||||
| 	install -m644 $(LIB_STATIC) $(DESTDIR)/$(usrlibdir) | ||||
| 	install -m644 $(LIB_SHARED) $(DESTDIR)/$(libdir) | ||||
| 	for i in $(LIB_INCLUDES); do \ | ||||
| 	  install -m644 include/$$i $(DESTDIR)/$(includedir)/$$i; \ | ||||
| 	done | ||||
| 	install -m644 $(LIB_MANS) $(DESTDIR)/$(mandir)/man3 | ||||
| 	install -m644 $(LIB_PKGCONFIG) $(DESTDIR)/$(pkgconfigdir) | ||||
| ifeq ($(libdir),$(usrlibdir)) | ||||
| 	# If both dirs are the same, do a relative symlink. | ||||
| 	ln -sf $(LIB_SHARED) $(DESTDIR)/$(usrlibdir)/$(LIB_SHARED_SO) | ||||
| else | ||||
| 	# Otherwise, do an absolute one. | ||||
| 	ln -sf $(libdir)/$(LIB_SHARED) $(DESTDIR)/$(usrlibdir)/$(LIB_SHARED_SO) | ||||
| endif | ||||
| 	ln -sf $(LIB_SHARED) $(DESTDIR)/$(libdir)/$(LIB_SONAME) | ||||
|  | ||||
| .PHONY: clean | ||||
| clean: | ||||
| 	rm -f $(LIB_PKGCONFIG) | ||||
| 	rm -f $(LIB_GEN_SRCS) | ||||
| 	rm -f $(LIB_STATIC_OBJS) | ||||
| 	rm -f $(LIB_STATIC) | ||||
| 	rm -f $(LIB_SHARED_OBJS) | ||||
| 	rm -f $(LIB_SHARED) $(LIB_SONAME) $(LIB_SHARED_SO) | ||||
|  | ||||
							
								
								
									
										16
									
								
								Makefile.am
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								Makefile.am
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | ||||
| ## Process this file with automake to produce Makefile.in | ||||
|  | ||||
| SUBDIRS = include man src test | ||||
|  | ||||
| ACLOCAL_AMFLAGS = -I m4 | ||||
|  | ||||
| EXTRA_DIST = \ | ||||
| 	autogen \ | ||||
| 	get-version \ | ||||
| 	$(nil) | ||||
|  | ||||
| dist-hook: | ||||
| 	echo $(VERSION) >$(distdir)/.dist-version | ||||
| 	if [ -d .git ]; then \ | ||||
| 	  git log --stat -C >$(distdir)/ChangeLog; \ | ||||
| 	fi | ||||
							
								
								
									
										3
									
								
								README
									
									
									
									
									
								
							
							
						
						
									
										3
									
								
								README
									
									
									
									
									
								
							| @@ -27,6 +27,5 @@ The mail address is: | ||||
| Source Repository | ||||
| ----------------- | ||||
|  | ||||
|   <http://gitweb.freedesktop.org/?p=libbsd.git> | ||||
|   <http://cgit.freedesktop.org/libbsd> | ||||
|   <git://anongit.freedesktop.org/git/libbsd> | ||||
|  | ||||
|   | ||||
							
								
								
									
										1
									
								
								TODO
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								TODO
									
									
									
									
									
								
							| @@ -1,4 +1,3 @@ | ||||
| * Add more functions used by ported packages (check openssh). | ||||
| * Fix includes on man pages. | ||||
| * Add missing man pages. | ||||
| * Add a README.import file. | ||||
|   | ||||
							
								
								
									
										44
									
								
								Versions
									
									
									
									
									
								
							
							
						
						
									
										44
									
								
								Versions
									
									
									
									
									
								
							| @@ -1,44 +0,0 @@ | ||||
| LIBBSD_0.0 { | ||||
|   global: | ||||
|     arc4random; | ||||
|     arc4random_stir; | ||||
|     arc4random_addrandom; | ||||
|     bsd_getopt; optreset; | ||||
|     errc; warnc; verrc; vwarnc; | ||||
|     fgetln; | ||||
|     fgetwln; | ||||
|     fmtcheck; | ||||
|     heapsort; | ||||
|     humanize_number; | ||||
|     inet_net_pton; | ||||
|  | ||||
|     getprogname; setprogname; | ||||
|     strlcpy; | ||||
|     strlcat; | ||||
|  | ||||
|     setmode; | ||||
|     getmode; | ||||
|  | ||||
|     vis; strvis; strvisx; | ||||
|     unvis; strunvis; strunvisx; | ||||
|     MD5Init; | ||||
|     MD5Update; | ||||
|     MD5Pad; | ||||
|     MD5Final; | ||||
|     MD5Transform; | ||||
|     MD5End; | ||||
|     MD5File; | ||||
|     MD5FileChunk; | ||||
|     MD5Data; | ||||
|  | ||||
|   local: | ||||
|     *; | ||||
| }; | ||||
|  | ||||
| LIBBSD_0.1 { | ||||
|     strmode; | ||||
|  | ||||
|     __fdnlist; /* Private symbol, but libkvm uses it. */ | ||||
|     nlist; | ||||
| } LIBBSD_0.0; | ||||
|  | ||||
							
								
								
									
										5
									
								
								autogen
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										5
									
								
								autogen
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,5 @@ | ||||
| #!/bin/sh | ||||
|  | ||||
| mkdir -p m4 | ||||
| autoreconf -f -i | ||||
| rm -rf autom4te.cache | ||||
							
								
								
									
										87
									
								
								configure.ac
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										87
									
								
								configure.ac
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,87 @@ | ||||
| # Process this file with autoconf to produce a configure script. | ||||
|  | ||||
| AC_PREREQ([2.67]) | ||||
| AC_INIT([libbsd], m4_esyscmd([./get-version]), [libbsd@lists.freedesktop.org]) | ||||
| AC_CONFIG_SRCDIR([src/fgetln.c]) | ||||
| AC_CONFIG_AUX_DIR([build-aux]) | ||||
| AC_CONFIG_MACRO_DIR([m4]) | ||||
|  | ||||
| AM_INIT_AUTOMAKE([1.8 foreign nostdinc no-dist-gzip dist-xz]) | ||||
|  | ||||
| m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])], | ||||
|                             [AC_SUBST([AM_DEFAULT_VERBOSITY], [1])]) | ||||
|  | ||||
| # Check and store if we got user supplied variables | ||||
| user_CFLAGS=${CFLAGS-unset} | ||||
|  | ||||
| # Checks for operating system services and capabilities. | ||||
| AC_USE_SYSTEM_EXTENSIONS | ||||
| AC_SYS_LARGEFILE | ||||
|  | ||||
| LT_INIT | ||||
|  | ||||
| # Checks for programs. | ||||
| AC_PROG_CC | ||||
| AC_PROG_INSTALL | ||||
| AC_PROG_LN_S | ||||
|  | ||||
| # Set default compiler variables | ||||
| if test "$user_CFLAGS" = unset && test "$GCC" = yes; then | ||||
|   CFLAGS="$CFLAGS -Wall -Wextra -Wno-unused-variable -Wno-unused-parameter" | ||||
| fi | ||||
|  | ||||
| # Checks for libraries. | ||||
|  | ||||
| # Checks for header files. | ||||
| AC_CHECK_HEADERS([sys/ndir.h sys/dir.h dir.h dirent.h]) | ||||
|  | ||||
| # Checks for typedefs, structures, and compiler characteristics. | ||||
| AC_TYPE_UID_T | ||||
| AC_C_INLINE | ||||
| AC_C_TYPEOF | ||||
| AC_TYPE_INT64_T | ||||
| AC_TYPE_MODE_T | ||||
| AC_TYPE_OFF_T | ||||
| AC_TYPE_PID_T | ||||
| AC_TYPE_SIZE_T | ||||
| AC_TYPE_SSIZE_T | ||||
|  | ||||
| AC_CHECK_DECL([F_CLOSEM], | ||||
|               [AC_DEFINE([HAVE_FCNTL_CLOSEM], [1], | ||||
|                          [Define to 1 if you have fcntl(F_CLOSEM)])], | ||||
|               [], | ||||
|               [#include <limits.h> | ||||
|                #include <fcntl.h>]) | ||||
|  | ||||
| # Checks for library functions. | ||||
| AC_MSG_CHECKING([for program_invocation_short_name]) | ||||
| AC_LINK_IFELSE( | ||||
| 	[AC_LANG_PROGRAM([[#include <errno.h>]], | ||||
| 	                 [[const char *p = program_invocation_short_name;]])], | ||||
| 	[AC_DEFINE([HAVE_PROGRAM_INVOCATION_SHORT_NAME], [1], | ||||
| 	           [Define to 1 if you have program_invocation_short_name]) | ||||
| 	 AC_MSG_RESULT([yes])], | ||||
| 	[AC_MSG_RESULT([no])]) | ||||
|  | ||||
| AC_MSG_CHECKING([for __progname]) | ||||
| AC_LINK_IFELSE( | ||||
| 	[AC_LANG_PROGRAM([[]], | ||||
| 	                 [[extern char *__progname; | ||||
| 	                   const char *p = __progname;]])], | ||||
| 	[AC_DEFINE([HAVE___PROGNAME], [1], [Define to 1 if you have __progname]) | ||||
| 	 AC_MSG_RESULT([yes])], | ||||
| 	[AC_MSG_RESULT([no])]) | ||||
|  | ||||
| AC_CHECK_FUNCS([clearenv dirfd __fpurge getexecname getline sysconf]) | ||||
|  | ||||
| AC_CONFIG_FILES([ | ||||
| 	Makefile | ||||
| 	include/Makefile | ||||
| 	man/Makefile | ||||
| 	src/Makefile | ||||
| 	src/libbsd.pc | ||||
| 	src/libbsd-overlay.pc | ||||
| 	test/Makefile | ||||
| ]) | ||||
| AC_CONFIG_HEADERS([config.h]) | ||||
| AC_OUTPUT | ||||
							
								
								
									
										48
									
								
								get-version
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										48
									
								
								get-version
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,48 @@ | ||||
| #!/bin/sh | ||||
| # | ||||
| # get-version | ||||
| # | ||||
| # Copyright © 2009 Guillem Jover <guillem@hadrons.org> | ||||
| # | ||||
| # 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. | ||||
|  | ||||
| if [ -f .dist-version ]; then | ||||
|   # Get the version from the file distributed in the tarball. | ||||
|   version=$(cat .dist-version) | ||||
| elif [ -d .git ]; then | ||||
|   # Ger the version from the git repository. | ||||
|   version=$(git describe --abbrev=4 HEAD 2>/dev/null) | ||||
|  | ||||
|   # Check if we are on a dirty checkout. | ||||
|   git update-index --refresh -q >/dev/null | ||||
|   dirty=$(git diff-index --name-only HEAD 2>/dev/null) | ||||
|   if [ -n "$dirty" ]; then | ||||
|     version="$version-dirty" | ||||
|   fi | ||||
| else | ||||
|   echo "error: cannot get project version." 1>&2 | ||||
|   exit 1 | ||||
| fi | ||||
|  | ||||
| # Use printf to avoid the trailing new line that m4_esyscmd would not handle. | ||||
| printf "$version" | ||||
							
								
								
									
										25
									
								
								include/Makefile.am
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								include/Makefile.am
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,25 @@ | ||||
| ## Process this file with automake to produce Makefile.in | ||||
|  | ||||
| nobase_include_HEADERS = \ | ||||
| 	bsd/sys/bitstring.h \ | ||||
| 	bsd/sys/cdefs.h \ | ||||
| 	bsd/sys/endian.h \ | ||||
| 	bsd/sys/poll.h \ | ||||
| 	bsd/sys/queue.h \ | ||||
| 	bsd/sys/tree.h \ | ||||
| 	bsd/netinet/ip_icmp.h \ | ||||
| 	bsd/bitstring.h \ | ||||
| 	bsd/bsd.h \ | ||||
| 	bsd/err.h \ | ||||
| 	bsd/getopt.h \ | ||||
| 	bsd/libutil.h \ | ||||
| 	bsd/md5.h \ | ||||
| 	bsd/nlist.h \ | ||||
| 	bsd/readpassphrase.h \ | ||||
| 	bsd/stdio.h \ | ||||
| 	bsd/stdlib.h \ | ||||
| 	bsd/string.h \ | ||||
| 	bsd/unistd.h \ | ||||
| 	bsd/vis.h \ | ||||
| 	bsd/wchar.h \ | ||||
| 	$(nil) | ||||
| @@ -1,5 +1,5 @@ | ||||
| /*
 | ||||
|  * Copyright © 2008, 2009 Guillem Jover | ||||
|  * Copyright © 2012 Guillem Jover <guillem@hadrons.org> | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
|  * modification, are permitted provided that the following conditions | ||||
| @@ -24,15 +24,9 @@ | ||||
|  * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  */ | ||||
| 
 | ||||
| #ifndef LIBBSD_INET_H | ||||
| #define LIBBSD_INET_H | ||||
| 
 | ||||
| #include <sys/cdefs.h> | ||||
| #include <stddef.h> | ||||
| 
 | ||||
| __BEGIN_DECLS | ||||
| int inet_net_pton(int af, const char *src, void *dst, siez_t size); | ||||
| __END_DECLS | ||||
| 
 | ||||
| /* For compatibility with NetBSD and OpenBSD. */ | ||||
| #ifdef LIBBSD_OVERLAY | ||||
| #include <sys/bitstring.h> | ||||
| #else | ||||
| #include <bsd/sys/bitstring.h> | ||||
| #endif | ||||
| 
 | ||||
| @@ -1,5 +1,5 @@ | ||||
| /* | ||||
|  * Copyright © 2004, 2005, 2006 Guillem Jover | ||||
|  * Copyright © 2004, 2005, 2006 Guillem Jover <guillem@hadrons.org> | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
|  * modification, are permitted provided that the following conditions | ||||
| @@ -31,15 +31,14 @@ | ||||
|  * Include all bsd compat headers. | ||||
|  */ | ||||
|  | ||||
| #include <bsd/cdefs.h> | ||||
| #include <bsd/sys/cdefs.h> | ||||
| #include <bsd/sys/queue.h> | ||||
| #include <bsd/sys/tree.h> | ||||
| #include <bsd/netinet/ip_icmp.h> | ||||
| #include <bsd/stdlib.h> | ||||
| #include <bsd/string.h> | ||||
| #include <bsd/err.h> | ||||
| #include <bsd/getopt.h> | ||||
| #include <bsd/random.h> | ||||
| #include <bsd/md5.h> | ||||
| #include <bsd/queue.h> | ||||
| #include <bsd/ip_icmp.h> | ||||
| #include <time.h> | ||||
|  | ||||
| #endif | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| /* | ||||
|  * Copyright © 2006 Robert Millan | ||||
|  * Copyright © 2009 Guillem Jover | ||||
|  * Copyright © 2009, 2011 Guillem Jover <guillem@hadrons.org> | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
|  * modification, are permitted provided that the following conditions | ||||
| @@ -25,11 +25,17 @@ | ||||
|  * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  */ | ||||
|  | ||||
| #ifdef LIBBSD_OVERLAY | ||||
| #include_next <err.h> | ||||
| #else | ||||
| #include <err.h> | ||||
| #endif | ||||
|  | ||||
| #ifndef LIBBSD_ERR_H | ||||
| #define LIBBSD_ERR_H | ||||
|  | ||||
| #include <sys/cdefs.h> | ||||
| #include <err.h> | ||||
|  | ||||
| #include <stdarg.h> | ||||
|  | ||||
| __BEGIN_DECLS | ||||
|   | ||||
| @@ -1,6 +1,5 @@ | ||||
| /* | ||||
|  * Copyright © 2006 Robert Millan | ||||
|  * Copyright © 2009 Guillem Jover | ||||
|  * Copyright © 2011 Guillem Jover <guillem@hadrons.org> | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
|  * modification, are permitted provided that the following conditions | ||||
| @@ -25,16 +24,10 @@ | ||||
|  * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  */ | ||||
|  | ||||
| #ifndef LIBBSD_GETOPT_H | ||||
| #define LIBBSD_GETOPT_H | ||||
|  | ||||
| #include <sys/cdefs.h> | ||||
| #ifdef LIBBSD_OVERLAY | ||||
| #include_next <getopt.h> | ||||
| #include <unistd.h> | ||||
| #else | ||||
| #include <getopt.h> | ||||
|  | ||||
| __BEGIN_DECLS | ||||
| extern int optreset; | ||||
|  | ||||
| int bsd_getopt (int, char **, char *); | ||||
| __END_DECLS | ||||
|  | ||||
| #include <bsd/unistd.h> | ||||
| #endif | ||||
|   | ||||
| @@ -40,12 +40,32 @@ | ||||
| #define _LIBUTIL_H_ | ||||
| 
 | ||||
| #include <features.h> | ||||
| #include <sys/cdefs.h> | ||||
| #include <sys/types.h> | ||||
| #include <stdint.h> | ||||
| #include <stdio.h> | ||||
| 
 | ||||
| /* for pidfile.c */ | ||||
| struct pidfh { | ||||
| 	int	pf_fd; | ||||
| 	char	*pf_path; | ||||
| 	dev_t	pf_dev; | ||||
| 	ino_t	pf_ino; | ||||
| }; | ||||
| 
 | ||||
| __BEGIN_DECLS | ||||
| int humanize_number(char *buf, size_t len, int64_t bytes, | ||||
|     const char *suffix, int scale, int flags); | ||||
| int expand_number(const char *_buf, uint64_t *_num); | ||||
| 
 | ||||
| int flopen(const char *_path, int _flags, ...); | ||||
| 
 | ||||
| struct pidfh *pidfile_open(const char *path, mode_t mode, pid_t *pidptr); | ||||
| int pidfile_write(struct pidfh *pfh); | ||||
| int pidfile_close(struct pidfh *pfh); | ||||
| int pidfile_remove(struct pidfh *pfh); | ||||
| 
 | ||||
| char   *fparseln(FILE *, size_t *, size_t *, const char[3], int); | ||||
| __END_DECLS | ||||
| 
 | ||||
| /* humanize_number(3) */ | ||||
| @@ -57,4 +77,13 @@ __END_DECLS | ||||
| #define HN_GETSCALE             0x10 | ||||
| #define HN_AUTOSCALE            0x20 | ||||
| 
 | ||||
| /*
 | ||||
|  * fparseln() specific operation flags. | ||||
|  */ | ||||
| #define FPARSELN_UNESCESC	0x01 | ||||
| #define FPARSELN_UNESCCONT	0x02 | ||||
| #define FPARSELN_UNESCCOMM	0x04 | ||||
| #define FPARSELN_UNESCREST	0x08 | ||||
| #define FPARSELN_UNESCALL	0x0f | ||||
| 
 | ||||
| #endif /* !_LIBUTIL_H_ */ | ||||
| @@ -1,5 +1,5 @@ | ||||
| /*
 | ||||
|  * Copyright © 2009 Guillem Jover | ||||
|  * Copyright © 2009 Guillem Jover <guillem@hadrons.org> | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
|  * modification, are permitted provided that the following conditions | ||||
| @@ -35,4 +35,3 @@ extern int nlist(const char *filename, struct nlist *list); | ||||
| __END_DECLS | ||||
| 
 | ||||
| #endif | ||||
| 
 | ||||
							
								
								
									
										41
									
								
								include/bsd/readpassphrase.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								include/bsd/readpassphrase.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,41 @@ | ||||
| /*	$OpenBSD: readpassphrase.h,v 1.4 2003/06/03 01:52:39 millert Exp $	*/ | ||||
|  | ||||
| /* | ||||
|  * Copyright (c) 2000, 2002 Todd C. Miller <Todd.Miller@courtesan.com> | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this software for any | ||||
|  * purpose with or without fee is hereby granted, provided that the above | ||||
|  * copyright notice and this permission notice appear in all copies. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | ||||
|  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | ||||
|  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | ||||
|  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | ||||
|  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | ||||
|  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF | ||||
|  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||||
|  * | ||||
|  * Sponsored in part by the Defense Advanced Research Projects | ||||
|  * Agency (DARPA) and Air Force Research Laboratory, Air Force | ||||
|  * Materiel Command, USAF, under agreement number F39502-99-1-0512. | ||||
|  */ | ||||
|  | ||||
| #ifndef _READPASSPHRASE_H_ | ||||
| #define _READPASSPHRASE_H_ | ||||
|  | ||||
| #define RPP_ECHO_OFF    0x00		/* Turn off echo (default). */ | ||||
| #define RPP_ECHO_ON     0x01		/* Leave echo on. */ | ||||
| #define RPP_REQUIRE_TTY 0x02		/* Fail if there is no tty. */ | ||||
| #define RPP_FORCELOWER  0x04		/* Force input to lower case. */ | ||||
| #define RPP_FORCEUPPER  0x08		/* Force input to upper case. */ | ||||
| #define RPP_SEVENBIT    0x10		/* Strip the high bit from input. */ | ||||
| #define RPP_STDIN       0x20		/* Read from stdin, not /dev/tty */ | ||||
|  | ||||
| #include <sys/cdefs.h> | ||||
| #include <sys/types.h> | ||||
|  | ||||
| __BEGIN_DECLS | ||||
| char * readpassphrase(const char *, char *, size_t, int); | ||||
| __END_DECLS | ||||
|  | ||||
| #endif /* !_READPASSPHRASE_H_ */ | ||||
							
								
								
									
										47
									
								
								include/bsd/stdio.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										47
									
								
								include/bsd/stdio.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,47 @@ | ||||
| /* | ||||
|  * Copyright © 2004, 2005, 2009, 2011 Guillem Jover <guillem@hadrons.org> | ||||
|  * | ||||
|  * 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. | ||||
|  */ | ||||
|  | ||||
| #ifdef LIBBSD_OVERLAY | ||||
| #include_next <stdio.h> | ||||
| #else | ||||
| #include <stdio.h> | ||||
| #endif | ||||
|  | ||||
| #ifndef LIBBSD_STDIO_H | ||||
| #define LIBBSD_STDIO_H | ||||
|  | ||||
| #include <sys/cdefs.h> | ||||
| #include <sys/types.h> | ||||
|  | ||||
| __BEGIN_DECLS | ||||
| const char *fmtcheck(const char *, const char *); | ||||
|  | ||||
| char *fgetln(FILE *fp, size_t *lenp); | ||||
|  | ||||
| int fpurge(FILE *fp); | ||||
| __END_DECLS | ||||
|  | ||||
| #endif | ||||
| @@ -1,7 +1,7 @@ | ||||
| /* | ||||
|  * Copyright © 2005 Aurelien Jarno | ||||
|  * Copyright © 2006 Robert Millan | ||||
|  * Copyright © 2008, 2009 Guillem Jover | ||||
|  * Copyright © 2008-2011 Guillem Jover <guillem@hadrons.org> | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
|  * modification, are permitted provided that the following conditions | ||||
| @@ -26,27 +26,50 @@ | ||||
|  * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  */ | ||||
|  | ||||
| #ifdef LIBBSD_OVERLAY | ||||
| #include_next <stdlib.h> | ||||
| #else | ||||
| #include <stdlib.h> | ||||
| #endif | ||||
|  | ||||
| /* For compatibility with NetBSD, which defines humanize_number here. */ | ||||
| #ifdef LIBBSD_OVERLAY | ||||
| #include <libutil.h> | ||||
| #else | ||||
| #include <bsd/libutil.h> | ||||
| #endif | ||||
|  | ||||
| #ifndef LIBBSD_STDLIB_H | ||||
| #define LIBBSD_STDLIB_H | ||||
|  | ||||
| #include <sys/cdefs.h> | ||||
| #include <sys/stat.h> | ||||
| #include <stdlib.h> | ||||
| #include <stdint.h> | ||||
|  | ||||
| __BEGIN_DECLS | ||||
| const char *fmtcheck (const char *, const char *); | ||||
| u_int32_t arc4random(); | ||||
| void arc4random_stir(); | ||||
| void arc4random_addrandom(u_char *dat, int datlen); | ||||
| void arc4random_buf(void *_buf, size_t n); | ||||
| u_int32_t arc4random_uniform(u_int32_t upper_bound); | ||||
|  | ||||
| char *getprogname (); | ||||
| void setprogname (char *); | ||||
| int dehumanize_number(const char *str, int64_t *size); | ||||
|  | ||||
| const char *getprogname(void); | ||||
| void setprogname(const char *); | ||||
|  | ||||
| int heapsort (void *, size_t, size_t, int (*)(const void *, const void *)); | ||||
| int mergesort(void *base, size_t nmemb, size_t size, | ||||
|               int (*cmp)(const void *, const void *)); | ||||
| int radixsort(const unsigned char **base, int nmemb, | ||||
|               const unsigned char *table, unsigned endbyte); | ||||
| int sradixsort(const unsigned char **base, int nmemb, | ||||
|                const unsigned char *table, unsigned endbyte); | ||||
|  | ||||
| #ifndef S_ISTXT | ||||
| #define S_ISTXT S_ISVTX | ||||
| #endif | ||||
| void *reallocf(void *ptr, size_t size); | ||||
|  | ||||
| mode_t getmode(const void *set, mode_t mode); | ||||
| void *setmode(const char *mode_str); | ||||
| long long strtonum(const char *nptr, long long minval, long long maxval, | ||||
|                    const char **errstr); | ||||
| __END_DECLS | ||||
|  | ||||
| #endif | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| /* | ||||
|  * Copyright © 2004, 2005, 2009 Guillem Jover | ||||
|  * Copyright © 2004, 2005, 2009, 2011 Guillem Jover <guillem@hadrons.org> | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
|  * modification, are permitted provided that the following conditions | ||||
| @@ -24,20 +24,22 @@ | ||||
|  * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  */ | ||||
|  | ||||
| #ifdef LIBBSD_OVERLAY | ||||
| #include_next <string.h> | ||||
| #else | ||||
| #include <string.h> | ||||
| #endif | ||||
|  | ||||
| #ifndef LIBBSD_STRING_H | ||||
| #define LIBBSD_STRING_H | ||||
|  | ||||
| #include <sys/cdefs.h> | ||||
| #include <sys/types.h> | ||||
| #include <stddef.h> | ||||
| #include <stdio.h> | ||||
|  | ||||
| __BEGIN_DECLS | ||||
| size_t strlcpy(char *dst, const char *src, size_t siz); | ||||
| size_t strlcat(char *dst, const char *src, size_t siz); | ||||
| char *fgetln(FILE *fp, size_t *lenp); | ||||
| wchar_t *fgetwln(FILE * __restrict fp, size_t *lenp); | ||||
|  | ||||
| char *strnstr(const char *str, const char *find, size_t str_len); | ||||
| void strmode(mode_t mode, char *str); | ||||
| __END_DECLS | ||||
|  | ||||
|   | ||||
							
								
								
									
										146
									
								
								include/bsd/sys/bitstring.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										146
									
								
								include/bsd/sys/bitstring.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,146 @@ | ||||
| /*- | ||||
|  * Copyright (c) 1989, 1993 | ||||
|  *	The Regents of the University of California.  All rights reserved. | ||||
|  * | ||||
|  * This code is derived from software contributed to Berkeley by | ||||
|  * Paul Vixie. | ||||
|  * | ||||
|  * 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. | ||||
|  * 4. Neither the name of the University nor the names of its contributors | ||||
|  *    may be used to endorse or promote products derived from this software | ||||
|  *    without specific prior written permission. | ||||
|  * | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``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 REGENTS OR CONTRIBUTORS 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. | ||||
|  * | ||||
|  * $FreeBSD$ | ||||
|  */ | ||||
|  | ||||
| #ifndef _SYS_BITSTRING_H_ | ||||
| #define	_SYS_BITSTRING_H_ | ||||
|  | ||||
| typedef	unsigned char bitstr_t; | ||||
|  | ||||
| /* internal macros */ | ||||
| 				/* byte of the bitstring bit is in */ | ||||
| #define	_bit_byte(bit) \ | ||||
| 	((bit) >> 3) | ||||
|  | ||||
| 				/* mask for the bit within its byte */ | ||||
| #define	_bit_mask(bit) \ | ||||
| 	(1 << ((bit)&0x7)) | ||||
|  | ||||
| /* external macros */ | ||||
| 				/* bytes in a bitstring of nbits bits */ | ||||
| #define	bitstr_size(nbits) \ | ||||
| 	(((nbits) + 7) >> 3) | ||||
|  | ||||
| 				/* allocate a bitstring */ | ||||
| #define	bit_alloc(nbits) \ | ||||
| 	(bitstr_t *)calloc((size_t)bitstr_size(nbits), sizeof(bitstr_t)) | ||||
|  | ||||
| 				/* allocate a bitstring on the stack */ | ||||
| #define	bit_decl(name, nbits) \ | ||||
| 	((name)[bitstr_size(nbits)]) | ||||
|  | ||||
| 				/* is bit N of bitstring name set? */ | ||||
| #define	bit_test(name, bit) \ | ||||
| 	((name)[_bit_byte(bit)] & _bit_mask(bit)) | ||||
|  | ||||
| 				/* set bit N of bitstring name */ | ||||
| #define	bit_set(name, bit) \ | ||||
| 	((name)[_bit_byte(bit)] |= _bit_mask(bit)) | ||||
|  | ||||
| 				/* clear bit N of bitstring name */ | ||||
| #define	bit_clear(name, bit) \ | ||||
| 	((name)[_bit_byte(bit)] &= ~_bit_mask(bit)) | ||||
|  | ||||
| 				/* clear bits start ... stop in bitstring */ | ||||
| #define	bit_nclear(name, start, stop) do { \ | ||||
| 	register bitstr_t *_name = (name); \ | ||||
| 	register int _start = (start), _stop = (stop); \ | ||||
| 	register int _startbyte = _bit_byte(_start); \ | ||||
| 	register int _stopbyte = _bit_byte(_stop); \ | ||||
| 	if (_startbyte == _stopbyte) { \ | ||||
| 		_name[_startbyte] &= ((0xff >> (8 - (_start&0x7))) | \ | ||||
| 				      (0xff << ((_stop&0x7) + 1))); \ | ||||
| 	} else { \ | ||||
| 		_name[_startbyte] &= 0xff >> (8 - (_start&0x7)); \ | ||||
| 		while (++_startbyte < _stopbyte) \ | ||||
| 			_name[_startbyte] = 0; \ | ||||
| 		_name[_stopbyte] &= 0xff << ((_stop&0x7) + 1); \ | ||||
| 	} \ | ||||
| } while (0) | ||||
|  | ||||
| 				/* set bits start ... stop in bitstring */ | ||||
| #define	bit_nset(name, start, stop) do { \ | ||||
| 	register bitstr_t *_name = (name); \ | ||||
| 	register int _start = (start), _stop = (stop); \ | ||||
| 	register int _startbyte = _bit_byte(_start); \ | ||||
| 	register int _stopbyte = _bit_byte(_stop); \ | ||||
| 	if (_startbyte == _stopbyte) { \ | ||||
| 		_name[_startbyte] |= ((0xff << (_start&0x7)) & \ | ||||
| 				    (0xff >> (7 - (_stop&0x7)))); \ | ||||
| 	} else { \ | ||||
| 		_name[_startbyte] |= 0xff << ((_start)&0x7); \ | ||||
| 		while (++_startbyte < _stopbyte) \ | ||||
| 	    		_name[_startbyte] = 0xff; \ | ||||
| 		_name[_stopbyte] |= 0xff >> (7 - (_stop&0x7)); \ | ||||
| 	} \ | ||||
| } while (0) | ||||
|  | ||||
| 				/* find first bit clear in name */ | ||||
| #define	bit_ffc(name, nbits, value) do { \ | ||||
| 	register bitstr_t *_name = (name); \ | ||||
| 	register int _byte, _nbits = (nbits); \ | ||||
| 	register int _stopbyte = _bit_byte(_nbits - 1), _value = -1; \ | ||||
| 	if (_nbits > 0) \ | ||||
| 		for (_byte = 0; _byte <= _stopbyte; ++_byte) \ | ||||
| 			if (_name[_byte] != 0xff) { \ | ||||
| 				bitstr_t _lb; \ | ||||
| 				_value = _byte << 3; \ | ||||
| 				for (_lb = _name[_byte]; (_lb&0x1); \ | ||||
| 				    ++_value, _lb >>= 1); \ | ||||
| 				break; \ | ||||
| 			} \ | ||||
| 	if (_value >= nbits) \ | ||||
| 		_value = -1; \ | ||||
| 	*(value) = _value; \ | ||||
| } while (0) | ||||
|  | ||||
| 				/* find first bit set in name */ | ||||
| #define	bit_ffs(name, nbits, value) do { \ | ||||
| 	register bitstr_t *_name = (name); \ | ||||
| 	register int _byte, _nbits = (nbits); \ | ||||
| 	register int _stopbyte = _bit_byte(_nbits - 1), _value = -1; \ | ||||
| 	if (_nbits > 0) \ | ||||
| 		for (_byte = 0; _byte <= _stopbyte; ++_byte) \ | ||||
| 			if (_name[_byte]) { \ | ||||
| 				bitstr_t _lb; \ | ||||
| 				_value = _byte << 3; \ | ||||
| 				for (_lb = _name[_byte]; !(_lb&0x1); \ | ||||
| 				    ++_value, _lb >>= 1); \ | ||||
| 				break; \ | ||||
| 			} \ | ||||
| 	if (_value >= nbits) \ | ||||
| 		_value = -1; \ | ||||
| 	*(value) = _value; \ | ||||
| } while (0) | ||||
|  | ||||
| #endif /* !_SYS_BITSTRING_H_ */ | ||||
							
								
								
									
										141
									
								
								include/bsd/sys/cdefs.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										141
									
								
								include/bsd/sys/cdefs.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,141 @@ | ||||
| /* | ||||
|  * Copyright © 2004-2006, 2009-2011 Guillem Jover <guillem@hadrons.org> | ||||
|  * | ||||
|  * 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. | ||||
|  */ | ||||
|  | ||||
| #ifdef LIBBSD_OVERLAY | ||||
| #include_next <sys/cdefs.h> | ||||
| #else | ||||
| #include <sys/cdefs.h> | ||||
| #endif | ||||
|  | ||||
| #ifndef LIBBSD_SYS_CDEFS_H | ||||
| #define LIBBSD_SYS_CDEFS_H | ||||
|  | ||||
| /* | ||||
|  * Some kFreeBSD headers expect those macros to be set for sanity checks. | ||||
|  */ | ||||
| #ifndef _SYS_CDEFS_H_ | ||||
| #define _SYS_CDEFS_H_ | ||||
| #endif | ||||
| #ifndef _SYS_CDEFS_H | ||||
| #define _SYS_CDEFS_H | ||||
| #endif | ||||
|  | ||||
| #ifdef __GNUC__ | ||||
| #define LIBBSD_GCC_VERSION (__GNUC__ << 8 | __GNUC_MINOR__) | ||||
| #else | ||||
| #define LIBBSD_GCC_VERSION 0 | ||||
| #endif | ||||
|  | ||||
| #ifndef __dead2 | ||||
| # if LIBBSD_GCC_VERSION >= 0x0207 | ||||
| #  define __dead2 __attribute__((__noreturn__)) | ||||
| # else | ||||
| #  define __dead2 | ||||
| # endif | ||||
| #endif | ||||
|  | ||||
| #ifndef __pure2 | ||||
| # if LIBBSD_GCC_VERSION >= 0x0207 | ||||
| #  define __pure2 __attribute__((__const__)) | ||||
| # else | ||||
| #  define __pure2 | ||||
| # endif | ||||
| #endif | ||||
|  | ||||
| #ifndef __packed | ||||
| # if LIBBSD_GCC_VERSION >= 0x0207 | ||||
| #  define __packed __attribute__((__packed__)) | ||||
| # else | ||||
| #  define __packed | ||||
| # endif | ||||
| #endif | ||||
|  | ||||
| #ifndef __aligned | ||||
| # if LIBBSD_GCC_VERSION >= 0x0207 | ||||
| #  define __aligned(x) __attribute__((__aligned__(x))) | ||||
| # else | ||||
| #  define __aligned(x) | ||||
| # endif | ||||
| #endif | ||||
|  | ||||
| /* Linux headers define a struct with a member names __unused. | ||||
|  * Debian bugs: #522773 (linux), #522774 (libc). | ||||
|  * Disable for now. */ | ||||
| #if 0 | ||||
| #ifndef __unused | ||||
| # if LIBBSD_GCC_VERSION >= 0x0300 | ||||
| #  define __unused __attribute__((unused)) | ||||
| # else | ||||
| #  define __unused | ||||
| # endif | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| #ifndef __printflike | ||||
| # if LIBBSD_GCC_VERSION >= 0x0300 | ||||
| #  define __printflike(x, y) __attribute((format(printf, (x), (y)))) | ||||
| # else | ||||
| #  define __printflike(x, y) | ||||
| # endif | ||||
| #endif | ||||
|  | ||||
| #ifndef __nonnull | ||||
| # if LIBBSD_GCC_VERSION >= 0x0302 | ||||
| #  define __nonnull(x) __attribute__((__nonnull__(x))) | ||||
| # else | ||||
| #  define __nonnull(x) | ||||
| # endif | ||||
| #endif | ||||
|  | ||||
| #ifndef __bounded__ | ||||
| # define __bounded__(x, y, z) | ||||
| #endif | ||||
|  | ||||
| #ifndef __RCSID | ||||
| # define __RCSID(x) | ||||
| #endif | ||||
|  | ||||
| #ifndef __FBSDID | ||||
| # define __FBSDID(x) | ||||
| #endif | ||||
|  | ||||
| #ifndef __RCSID | ||||
| # define __RCSID(x) | ||||
| #endif | ||||
|  | ||||
| #ifndef __RCSID_SOURCE | ||||
| # define __RCSID_SOURCE(x) | ||||
| #endif | ||||
|  | ||||
| #ifndef __SCCSID | ||||
| # define __SCCSID(x) | ||||
| #endif | ||||
|  | ||||
| #ifndef __COPYRIGHT | ||||
| # define __COPYRIGHT(x) | ||||
| #endif | ||||
|  | ||||
| #endif | ||||
							
								
								
									
										188
									
								
								include/bsd/sys/endian.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										188
									
								
								include/bsd/sys/endian.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,188 @@ | ||||
| /* | ||||
|  * Copyright © 2011 Guillem Jover <guillem@hadrons.org> | ||||
|  * | ||||
|  * 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. | ||||
|  */ | ||||
|  | ||||
| #ifdef LIBBSD_OVERLAY | ||||
| #include_next <endian.h> | ||||
| #else | ||||
| #include <endian.h> | ||||
| #endif | ||||
|  | ||||
| #ifndef LIBBSD_SYS_ENDIAN_H | ||||
| #define LIBBSD_SYS_ENDIAN_H | ||||
|  | ||||
| #ifndef _BYTE_ORDER | ||||
| #define _BYTE_ORDER __BYTE_ORDER | ||||
| #endif | ||||
|  | ||||
| #ifndef _LITTLE_ENDIAN | ||||
| #define _LITTLE_ENDIAN __LITTLE_ENDIAN | ||||
| #endif | ||||
|  | ||||
| #ifndef _BIG_ENDIAN | ||||
| #define _BIG_ENDIAN __BIG_ENDIAN | ||||
| #endif | ||||
|  | ||||
| #ifndef _PDP_ENDIAN | ||||
| #define _PDP_ENDIAN __PDP_ENDIAN | ||||
| #endif | ||||
|  | ||||
| /* | ||||
|  * Copyright © 2002 Thomas Moestl <tmm@FreeBSD.org> | ||||
|  * All rights reserved. | ||||
|  * | ||||
|  * 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. | ||||
|  * | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``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 OR CONTRIBUTORS 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. | ||||
|  */ | ||||
|  | ||||
| #include <stdint.h> | ||||
|  | ||||
| /* Alignment-agnostic encode/decode bytestream to/from little/big endian. */ | ||||
|  | ||||
| static __inline uint16_t | ||||
| be16dec(const void *pp) | ||||
| { | ||||
| 	uint8_t const *p = (uint8_t const *)pp; | ||||
|  | ||||
| 	return ((p[0] << 8) | p[1]); | ||||
| } | ||||
|  | ||||
| static __inline uint32_t | ||||
| be32dec(const void *pp) | ||||
| { | ||||
| 	uint8_t const *p = (uint8_t const *)pp; | ||||
|  | ||||
| 	return (((unsigned)p[0] << 24) | (p[1] << 16) | (p[2] << 8) | p[3]); | ||||
| } | ||||
|  | ||||
| static __inline uint64_t | ||||
| be64dec(const void *pp) | ||||
| { | ||||
| 	uint8_t const *p = (uint8_t const *)pp; | ||||
|  | ||||
| 	return (((uint64_t)be32dec(p) << 32) | be32dec(p + 4)); | ||||
| } | ||||
|  | ||||
| static __inline uint16_t | ||||
| le16dec(const void *pp) | ||||
| { | ||||
| 	uint8_t const *p = (uint8_t const *)pp; | ||||
|  | ||||
| 	return ((p[1] << 8) | p[0]); | ||||
| } | ||||
|  | ||||
| static __inline uint32_t | ||||
| le32dec(const void *pp) | ||||
| { | ||||
| 	uint8_t const *p = (uint8_t const *)pp; | ||||
|  | ||||
| 	return (((unsigned)p[3] << 24) | (p[2] << 16) | (p[1] << 8) | p[0]); | ||||
| } | ||||
|  | ||||
| static __inline uint64_t | ||||
| le64dec(const void *pp) | ||||
| { | ||||
| 	uint8_t const *p = (uint8_t const *)pp; | ||||
|  | ||||
| 	return (((uint64_t)le32dec(p + 4) << 32) | le32dec(p)); | ||||
| } | ||||
|  | ||||
| static __inline void | ||||
| be16enc(void *pp, uint16_t u) | ||||
| { | ||||
| 	uint8_t *p = (uint8_t *)pp; | ||||
|  | ||||
| 	p[0] = (u >> 8) & 0xff; | ||||
| 	p[1] = u & 0xff; | ||||
| } | ||||
|  | ||||
| static __inline void | ||||
| be32enc(void *pp, uint32_t u) | ||||
| { | ||||
| 	uint8_t *p = (uint8_t *)pp; | ||||
|  | ||||
| 	p[0] = (u >> 24) & 0xff; | ||||
| 	p[1] = (u >> 16) & 0xff; | ||||
| 	p[2] = (u >> 8) & 0xff; | ||||
| 	p[3] = u & 0xff; | ||||
| } | ||||
|  | ||||
| static __inline void | ||||
| be64enc(void *pp, uint64_t u) | ||||
| { | ||||
| 	uint8_t *p = (uint8_t *)pp; | ||||
|  | ||||
| 	be32enc(p, (uint32_t)(u >> 32)); | ||||
| 	be32enc(p + 4, (uint32_t)(u & 0xffffffffU)); | ||||
| } | ||||
|  | ||||
| static __inline void | ||||
| le16enc(void *pp, uint16_t u) | ||||
| { | ||||
| 	uint8_t *p = (uint8_t *)pp; | ||||
|  | ||||
| 	p[0] = u & 0xff; | ||||
| 	p[1] = (u >> 8) & 0xff; | ||||
| } | ||||
|  | ||||
| static __inline void | ||||
| le32enc(void *pp, uint32_t u) | ||||
| { | ||||
| 	uint8_t *p = (uint8_t *)pp; | ||||
|  | ||||
| 	p[0] = u & 0xff; | ||||
| 	p[1] = (u >> 8) & 0xff; | ||||
| 	p[2] = (u >> 16) & 0xff; | ||||
| 	p[3] = (u >> 24) & 0xff; | ||||
| } | ||||
|  | ||||
| static __inline void | ||||
| le64enc(void *pp, uint64_t u) | ||||
| { | ||||
| 	uint8_t *p = (uint8_t *)pp; | ||||
|  | ||||
| 	le32enc(p, (uint32_t)(u & 0xffffffffU)); | ||||
| 	le32enc(p + 4, (uint32_t)(u >> 32)); | ||||
| } | ||||
|  | ||||
| #endif | ||||
| @@ -1,5 +1,5 @@ | ||||
| /*
 | ||||
|  * Copyright © 2004, 2005, 2009 Guillem Jover | ||||
|  * Copyright © 2011 Guillem Jover <guillem@hadrons.org> | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
|  * modification, are permitted provided that the following conditions | ||||
| @@ -24,17 +24,17 @@ | ||||
|  * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  */ | ||||
| 
 | ||||
| #ifndef LIBBSD_RANDOM_H | ||||
| #define LIBBSD_RANDOM_H | ||||
| 
 | ||||
| #include <sys/cdefs.h> | ||||
| #include <sys/types.h> | ||||
| 
 | ||||
| __BEGIN_DECLS | ||||
| u_int32_t arc4random(); | ||||
| void arc4random_stir(); | ||||
| void arc4random_addrandom(u_char *dat, int datlen); | ||||
| __END_DECLS | ||||
| 
 | ||||
| #ifdef LIBBSD_OVERLAY | ||||
| #include_next <sys/poll.h> | ||||
| #else | ||||
| #include <sys/poll.h> | ||||
| #endif | ||||
| 
 | ||||
| #ifndef LIBBSD_SYS_POLL_H | ||||
| #define LIBBSD_SYS_POLL_H | ||||
| 
 | ||||
| #ifndef INFTIM | ||||
| #define INFTIM (-1) | ||||
| #endif | ||||
| 
 | ||||
| #endif | ||||
| @@ -1,4 +1,4 @@ | ||||
| /*
 | ||||
| /*-
 | ||||
|  * Copyright (c) 1991, 1993 | ||||
|  *	The Regents of the University of California.  All rights reserved. | ||||
|  * | ||||
| @@ -10,7 +10,7 @@ | ||||
|  * 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. Neither the name of the University nor the names of its contributors | ||||
|  * 4. Neither the name of the University nor the names of its contributors | ||||
|  *    may be used to endorse or promote products derived from this software | ||||
|  *    without specific prior written permission. | ||||
|  * | ||||
| @@ -27,11 +27,11 @@ | ||||
|  * SUCH DAMAGE. | ||||
|  * | ||||
|  *	@(#)queue.h	8.5 (Berkeley) 8/20/94 | ||||
|  * $FreeBSD: src/sys/sys/queue.h,v 1.58 2004/04/07 04:19:49 imp Exp $ | ||||
|  * $FreeBSD$ | ||||
|  */ | ||||
| 
 | ||||
| #ifndef _SYS_QUEUE_H | ||||
| #define	_SYS_QUEUE_H | ||||
| #ifndef _SYS_QUEUE_H_ | ||||
| #define	_SYS_QUEUE_H_ | ||||
| 
 | ||||
| #include <sys/cdefs.h> | ||||
| 
 | ||||
| @@ -96,12 +96,12 @@ | ||||
|  * _INSERT_AFTER		+	+	+	+ | ||||
|  * _INSERT_TAIL			-	-	+	+ | ||||
|  * _CONCAT			-	-	+	+ | ||||
|  * _REMOVE_AFTER		+	-	+	- | ||||
|  * _REMOVE_HEAD			+	-	+	- | ||||
|  * _REMOVE			+	+	+	+ | ||||
|  * | ||||
|  */ | ||||
| #define	QUEUE_MACRO_DEBUG 0 | ||||
| #if QUEUE_MACRO_DEBUG | ||||
| #ifdef QUEUE_MACRO_DEBUG | ||||
| /* Store the last 2 places the queue element or head was altered */ | ||||
| struct qm_trace { | ||||
| 	char * lastfile; | ||||
| @@ -196,9 +196,14 @@ struct {								\ | ||||
| 		struct type *curelm = SLIST_FIRST((head));		\ | ||||
| 		while (SLIST_NEXT(curelm, field) != (elm))		\ | ||||
| 			curelm = SLIST_NEXT(curelm, field);		\ | ||||
| 		SLIST_NEXT(curelm, field) =				\ | ||||
| 		    SLIST_NEXT(SLIST_NEXT(curelm, field), field);	\ | ||||
| 		SLIST_REMOVE_AFTER(curelm, field);			\ | ||||
| 	}								\ | ||||
| 	TRASHIT((elm)->field.sle_next);					\ | ||||
| } while (0) | ||||
| 
 | ||||
| #define SLIST_REMOVE_AFTER(elm, field) do {				\ | ||||
| 	SLIST_NEXT(elm, field) =					\ | ||||
| 	    SLIST_NEXT(SLIST_NEXT(elm, field), field);			\ | ||||
| } while (0) | ||||
| 
 | ||||
| #define	SLIST_REMOVE_HEAD(head, field) do {				\ | ||||
| @@ -287,10 +292,9 @@ struct {								\ | ||||
| 		struct type *curelm = STAILQ_FIRST((head));		\ | ||||
| 		while (STAILQ_NEXT(curelm, field) != (elm))		\ | ||||
| 			curelm = STAILQ_NEXT(curelm, field);		\ | ||||
| 		if ((STAILQ_NEXT(curelm, field) =			\ | ||||
| 		     STAILQ_NEXT(STAILQ_NEXT(curelm, field), field)) == NULL)\ | ||||
| 			(head)->stqh_last = &STAILQ_NEXT((curelm), field);\ | ||||
| 		STAILQ_REMOVE_AFTER(head, curelm, field);		\ | ||||
| 	}								\ | ||||
| 	TRASHIT((elm)->field.stqe_next);				\ | ||||
| } while (0) | ||||
| 
 | ||||
| #define	STAILQ_REMOVE_HEAD(head, field) do {				\ | ||||
| @@ -299,11 +303,26 @@ struct {								\ | ||||
| 		(head)->stqh_last = &STAILQ_FIRST((head));		\ | ||||
| } while (0) | ||||
| 
 | ||||
| #define	STAILQ_REMOVE_HEAD_UNTIL(head, elm, field) do {			\ | ||||
| 	if ((STAILQ_FIRST((head)) = STAILQ_NEXT((elm), field)) == NULL)	\ | ||||
| 		(head)->stqh_last = &STAILQ_FIRST((head));		\ | ||||
| #define STAILQ_REMOVE_AFTER(head, elm, field) do {			\ | ||||
| 	if ((STAILQ_NEXT(elm, field) =					\ | ||||
| 	     STAILQ_NEXT(STAILQ_NEXT(elm, field), field)) == NULL)	\ | ||||
| 		(head)->stqh_last = &STAILQ_NEXT((elm), field);		\ | ||||
| } while (0) | ||||
| 
 | ||||
| #define STAILQ_SWAP(head1, head2, type) do {				\ | ||||
| 	struct type *swap_first = STAILQ_FIRST(head1);			\ | ||||
| 	struct type **swap_last = (head1)->stqh_last;			\ | ||||
| 	STAILQ_FIRST(head1) = STAILQ_FIRST(head2);			\ | ||||
| 	(head1)->stqh_last = (head2)->stqh_last;			\ | ||||
| 	STAILQ_FIRST(head2) = swap_first;				\ | ||||
| 	(head2)->stqh_last = swap_last;					\ | ||||
| 	if (STAILQ_EMPTY(head1))					\ | ||||
| 		(head1)->stqh_last = &STAILQ_FIRST(head1);		\ | ||||
| 	if (STAILQ_EMPTY(head2))					\ | ||||
| 		(head2)->stqh_last = &STAILQ_FIRST(head2);		\ | ||||
| } while (0) | ||||
| 
 | ||||
| 
 | ||||
| /*
 | ||||
|  * List declarations. | ||||
|  */ | ||||
| @@ -325,6 +344,31 @@ struct {								\ | ||||
|  * List functions. | ||||
|  */ | ||||
| 
 | ||||
| #if (defined(_KERNEL) && defined(INVARIANTS)) | ||||
| #define	QMD_LIST_CHECK_HEAD(head, field) do {				\ | ||||
| 	if (LIST_FIRST((head)) != NULL &&				\ | ||||
| 	    LIST_FIRST((head))->field.le_prev !=			\ | ||||
| 	     &LIST_FIRST((head)))					\ | ||||
| 		panic("Bad list head %p first->prev != head", (head));	\ | ||||
| } while (0) | ||||
| 
 | ||||
| #define	QMD_LIST_CHECK_NEXT(elm, field) do {				\ | ||||
| 	if (LIST_NEXT((elm), field) != NULL &&				\ | ||||
| 	    LIST_NEXT((elm), field)->field.le_prev !=			\ | ||||
| 	     &((elm)->field.le_next))					\ | ||||
| 	     	panic("Bad link elm %p next->prev != elm", (elm));	\ | ||||
| } while (0) | ||||
| 
 | ||||
| #define	QMD_LIST_CHECK_PREV(elm, field) do {				\ | ||||
| 	if (*(elm)->field.le_prev != (elm))				\ | ||||
| 		panic("Bad link elm %p prev->next != elm", (elm));	\ | ||||
| } while (0) | ||||
| #else | ||||
| #define	QMD_LIST_CHECK_HEAD(head, field) | ||||
| #define	QMD_LIST_CHECK_NEXT(elm, field) | ||||
| #define	QMD_LIST_CHECK_PREV(elm, field) | ||||
| #endif /* (_KERNEL && INVARIANTS) */ | ||||
| 
 | ||||
| #define	LIST_EMPTY(head)	((head)->lh_first == NULL) | ||||
| 
 | ||||
| #define	LIST_FIRST(head)	((head)->lh_first) | ||||
| @@ -344,6 +388,7 @@ struct {								\ | ||||
| } while (0) | ||||
| 
 | ||||
| #define	LIST_INSERT_AFTER(listelm, elm, field) do {			\ | ||||
| 	QMD_LIST_CHECK_NEXT(listelm, field);				\ | ||||
| 	if ((LIST_NEXT((elm), field) = LIST_NEXT((listelm), field)) != NULL)\ | ||||
| 		LIST_NEXT((listelm), field)->field.le_prev =		\ | ||||
| 		    &LIST_NEXT((elm), field);				\ | ||||
| @@ -352,6 +397,7 @@ struct {								\ | ||||
| } while (0) | ||||
| 
 | ||||
| #define	LIST_INSERT_BEFORE(listelm, elm, field) do {			\ | ||||
| 	QMD_LIST_CHECK_PREV(listelm, field);				\ | ||||
| 	(elm)->field.le_prev = (listelm)->field.le_prev;		\ | ||||
| 	LIST_NEXT((elm), field) = (listelm);				\ | ||||
| 	*(listelm)->field.le_prev = (elm);				\ | ||||
| @@ -359,6 +405,7 @@ struct {								\ | ||||
| } while (0) | ||||
| 
 | ||||
| #define	LIST_INSERT_HEAD(head, elm, field) do {				\ | ||||
| 	QMD_LIST_CHECK_HEAD((head), field);				\ | ||||
| 	if ((LIST_NEXT((elm), field) = LIST_FIRST((head))) != NULL)	\ | ||||
| 		LIST_FIRST((head))->field.le_prev = &LIST_NEXT((elm), field);\ | ||||
| 	LIST_FIRST((head)) = (elm);					\ | ||||
| @@ -368,10 +415,24 @@ struct {								\ | ||||
| #define	LIST_NEXT(elm, field)	((elm)->field.le_next) | ||||
| 
 | ||||
| #define	LIST_REMOVE(elm, field) do {					\ | ||||
| 	QMD_LIST_CHECK_NEXT(elm, field);				\ | ||||
| 	QMD_LIST_CHECK_PREV(elm, field);				\ | ||||
| 	if (LIST_NEXT((elm), field) != NULL)				\ | ||||
| 		LIST_NEXT((elm), field)->field.le_prev = 		\ | ||||
| 		    (elm)->field.le_prev;				\ | ||||
| 	*(elm)->field.le_prev = LIST_NEXT((elm), field);		\ | ||||
| 	TRASHIT((elm)->field.le_next);					\ | ||||
| 	TRASHIT((elm)->field.le_prev);					\ | ||||
| } while (0) | ||||
| 
 | ||||
| #define LIST_SWAP(head1, head2, type, field) do {			\ | ||||
| 	struct type *swap_tmp = LIST_FIRST((head1));			\ | ||||
| 	LIST_FIRST((head1)) = LIST_FIRST((head2));			\ | ||||
| 	LIST_FIRST((head2)) = swap_tmp;					\ | ||||
| 	if ((swap_tmp = LIST_FIRST((head1))) != NULL)			\ | ||||
| 		swap_tmp->field.le_prev = &LIST_FIRST((head1));		\ | ||||
| 	if ((swap_tmp = LIST_FIRST((head2))) != NULL)			\ | ||||
| 		swap_tmp->field.le_prev = &LIST_FIRST((head2));		\ | ||||
| } while (0) | ||||
| 
 | ||||
| /*
 | ||||
| @@ -397,6 +458,37 @@ struct {								\ | ||||
| /*
 | ||||
|  * Tail queue functions. | ||||
|  */ | ||||
| #if (defined(_KERNEL) && defined(INVARIANTS)) | ||||
| #define	QMD_TAILQ_CHECK_HEAD(head, field) do {				\ | ||||
| 	if (!TAILQ_EMPTY(head) &&					\ | ||||
| 	    TAILQ_FIRST((head))->field.tqe_prev !=			\ | ||||
| 	     &TAILQ_FIRST((head)))					\ | ||||
| 		panic("Bad tailq head %p first->prev != head", (head));	\ | ||||
| } while (0) | ||||
| 
 | ||||
| #define	QMD_TAILQ_CHECK_TAIL(head, field) do {				\ | ||||
| 	if (*(head)->tqh_last != NULL)					\ | ||||
| 	    	panic("Bad tailq NEXT(%p->tqh_last) != NULL", (head)); 	\ | ||||
| } while (0) | ||||
| 
 | ||||
| #define	QMD_TAILQ_CHECK_NEXT(elm, field) do {				\ | ||||
| 	if (TAILQ_NEXT((elm), field) != NULL &&				\ | ||||
| 	    TAILQ_NEXT((elm), field)->field.tqe_prev !=			\ | ||||
| 	     &((elm)->field.tqe_next))					\ | ||||
| 		panic("Bad link elm %p next->prev != elm", (elm));	\ | ||||
| } while (0) | ||||
| 
 | ||||
| #define	QMD_TAILQ_CHECK_PREV(elm, field) do {				\ | ||||
| 	if (*(elm)->field.tqe_prev != (elm))				\ | ||||
| 		panic("Bad link elm %p prev->next != elm", (elm));	\ | ||||
| } while (0) | ||||
| #else | ||||
| #define	QMD_TAILQ_CHECK_HEAD(head, field) | ||||
| #define	QMD_TAILQ_CHECK_TAIL(head, headname) | ||||
| #define	QMD_TAILQ_CHECK_NEXT(elm, field) | ||||
| #define	QMD_TAILQ_CHECK_PREV(elm, field) | ||||
| #endif /* (_KERNEL && INVARIANTS) */ | ||||
| 
 | ||||
| #define	TAILQ_CONCAT(head1, head2, field) do {				\ | ||||
| 	if (!TAILQ_EMPTY(head2)) {					\ | ||||
| 		*(head1)->tqh_last = (head2)->tqh_first;		\ | ||||
| @@ -439,6 +531,7 @@ struct {								\ | ||||
| } while (0) | ||||
| 
 | ||||
| #define	TAILQ_INSERT_AFTER(head, listelm, elm, field) do {		\ | ||||
| 	QMD_TAILQ_CHECK_NEXT(listelm, field);				\ | ||||
| 	if ((TAILQ_NEXT((elm), field) = TAILQ_NEXT((listelm), field)) != NULL)\ | ||||
| 		TAILQ_NEXT((elm), field)->field.tqe_prev = 		\ | ||||
| 		    &TAILQ_NEXT((elm), field);				\ | ||||
| @@ -453,6 +546,7 @@ struct {								\ | ||||
| } while (0) | ||||
| 
 | ||||
| #define	TAILQ_INSERT_BEFORE(listelm, elm, field) do {			\ | ||||
| 	QMD_TAILQ_CHECK_PREV(listelm, field);				\ | ||||
| 	(elm)->field.tqe_prev = (listelm)->field.tqe_prev;		\ | ||||
| 	TAILQ_NEXT((elm), field) = (listelm);				\ | ||||
| 	*(listelm)->field.tqe_prev = (elm);				\ | ||||
| @@ -462,6 +556,7 @@ struct {								\ | ||||
| } while (0) | ||||
| 
 | ||||
| #define	TAILQ_INSERT_HEAD(head, elm, field) do {			\ | ||||
| 	QMD_TAILQ_CHECK_HEAD(head, field);				\ | ||||
| 	if ((TAILQ_NEXT((elm), field) = TAILQ_FIRST((head))) != NULL)	\ | ||||
| 		TAILQ_FIRST((head))->field.tqe_prev =			\ | ||||
| 		    &TAILQ_NEXT((elm), field);				\ | ||||
| @@ -474,6 +569,7 @@ struct {								\ | ||||
| } while (0) | ||||
| 
 | ||||
| #define	TAILQ_INSERT_TAIL(head, elm, field) do {			\ | ||||
| 	QMD_TAILQ_CHECK_TAIL(head, field);				\ | ||||
| 	TAILQ_NEXT((elm), field) = NULL;				\ | ||||
| 	(elm)->field.tqe_prev = (head)->tqh_last;			\ | ||||
| 	*(head)->tqh_last = (elm);					\ | ||||
| @@ -491,6 +587,8 @@ struct {								\ | ||||
| 	(*(((struct headname *)((elm)->field.tqe_prev))->tqh_last)) | ||||
| 
 | ||||
| #define	TAILQ_REMOVE(head, elm, field) do {				\ | ||||
| 	QMD_TAILQ_CHECK_NEXT(elm, field);				\ | ||||
| 	QMD_TAILQ_CHECK_PREV(elm, field);				\ | ||||
| 	if ((TAILQ_NEXT((elm), field)) != NULL)				\ | ||||
| 		TAILQ_NEXT((elm), field)->field.tqe_prev = 		\ | ||||
| 		    (elm)->field.tqe_prev;				\ | ||||
| @@ -504,50 +602,21 @@ struct {								\ | ||||
| 	QMD_TRACE_ELEM(&(elm)->field);					\ | ||||
| } while (0) | ||||
| 
 | ||||
| #define TAILQ_SWAP(head1, head2, type, field) do {			\ | ||||
| 	struct type *swap_first = (head1)->tqh_first;			\ | ||||
| 	struct type **swap_last = (head1)->tqh_last;			\ | ||||
| 	(head1)->tqh_first = (head2)->tqh_first;			\ | ||||
| 	(head1)->tqh_last = (head2)->tqh_last;				\ | ||||
| 	(head2)->tqh_first = swap_first;				\ | ||||
| 	(head2)->tqh_last = swap_last;					\ | ||||
| 	if ((swap_first = (head1)->tqh_first) != NULL)			\ | ||||
| 		swap_first->field.tqe_prev = &(head1)->tqh_first;	\ | ||||
| 	else								\ | ||||
| 		(head1)->tqh_last = &(head1)->tqh_first;		\ | ||||
| 	if ((swap_first = (head2)->tqh_first) != NULL)			\ | ||||
| 		swap_first->field.tqe_prev = &(head2)->tqh_first;	\ | ||||
| 	else								\ | ||||
| 		(head2)->tqh_last = &(head2)->tqh_first;		\ | ||||
| } while (0) | ||||
| 
 | ||||
| #ifdef _KERNEL | ||||
| 
 | ||||
| /*
 | ||||
|  * XXX insque() and remque() are an old way of handling certain queues. | ||||
|  * They bogusly assumes that all queue heads look alike. | ||||
|  */ | ||||
| 
 | ||||
| struct quehead { | ||||
| 	struct quehead *qh_link; | ||||
| 	struct quehead *qh_rlink; | ||||
| }; | ||||
| 
 | ||||
| #if defined(__GNUC__) || defined(__INTEL_COMPILER) | ||||
| 
 | ||||
| static __inline void | ||||
| insque(void *a, void *b) | ||||
| { | ||||
| 	struct quehead *element = (struct quehead *)a, | ||||
| 		 *head = (struct quehead *)b; | ||||
| 
 | ||||
| 	element->qh_link = head->qh_link; | ||||
| 	element->qh_rlink = head; | ||||
| 	head->qh_link = element; | ||||
| 	element->qh_link->qh_rlink = element; | ||||
| } | ||||
| 
 | ||||
| static __inline void | ||||
| remque(void *a) | ||||
| { | ||||
| 	struct quehead *element = (struct quehead *)a; | ||||
| 
 | ||||
| 	element->qh_link->qh_rlink = element->qh_rlink; | ||||
| 	element->qh_rlink->qh_link = element->qh_link; | ||||
| 	element->qh_rlink = 0; | ||||
| } | ||||
| 
 | ||||
| #else /* !(__GNUC__ || __INTEL_COMPILER) */ | ||||
| 
 | ||||
| void	insque(void *a, void *b); | ||||
| void	remque(void *a); | ||||
| 
 | ||||
| #endif /* __GNUC__ || __INTEL_COMPILER */ | ||||
| 
 | ||||
| #endif /* _KERNEL */ | ||||
| 
 | ||||
| #endif /* !_SYS_QUEUE_H */ | ||||
| #endif /* !_SYS_QUEUE_H_ */ | ||||
							
								
								
									
										765
									
								
								include/bsd/sys/tree.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										765
									
								
								include/bsd/sys/tree.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,765 @@ | ||||
| /*	$NetBSD: tree.h,v 1.8 2004/03/28 19:38:30 provos Exp $	*/ | ||||
| /*	$OpenBSD: tree.h,v 1.7 2002/10/17 21:51:54 art Exp $	*/ | ||||
| /* $FreeBSD$ */ | ||||
|  | ||||
| /*- | ||||
|  * Copyright 2002 Niels Provos <provos@citi.umich.edu> | ||||
|  * All rights reserved. | ||||
|  * | ||||
|  * 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. | ||||
|  * | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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. | ||||
|  */ | ||||
|  | ||||
| #ifndef	_SYS_TREE_H_ | ||||
| #define	_SYS_TREE_H_ | ||||
|  | ||||
| #include <sys/cdefs.h> | ||||
|  | ||||
| /* | ||||
|  * This file defines data structures for different types of trees: | ||||
|  * splay trees and red-black trees. | ||||
|  * | ||||
|  * A splay tree is a self-organizing data structure.  Every operation | ||||
|  * on the tree causes a splay to happen.  The splay moves the requested | ||||
|  * node to the root of the tree and partly rebalances it. | ||||
|  * | ||||
|  * This has the benefit that request locality causes faster lookups as | ||||
|  * the requested nodes move to the top of the tree.  On the other hand, | ||||
|  * every lookup causes memory writes. | ||||
|  * | ||||
|  * The Balance Theorem bounds the total access time for m operations | ||||
|  * and n inserts on an initially empty tree as O((m + n)lg n).  The | ||||
|  * amortized cost for a sequence of m accesses to a splay tree is O(lg n); | ||||
|  * | ||||
|  * A red-black tree is a binary search tree with the node color as an | ||||
|  * extra attribute.  It fulfills a set of conditions: | ||||
|  *	- every search path from the root to a leaf consists of the | ||||
|  *	  same number of black nodes, | ||||
|  *	- each red node (except for the root) has a black parent, | ||||
|  *	- each leaf node is black. | ||||
|  * | ||||
|  * Every operation on a red-black tree is bounded as O(lg n). | ||||
|  * The maximum height of a red-black tree is 2lg (n+1). | ||||
|  */ | ||||
|  | ||||
| #define SPLAY_HEAD(name, type)						\ | ||||
| struct name {								\ | ||||
| 	struct type *sph_root; /* root of the tree */			\ | ||||
| } | ||||
|  | ||||
| #define SPLAY_INITIALIZER(root)						\ | ||||
| 	{ NULL } | ||||
|  | ||||
| #define SPLAY_INIT(root) do {						\ | ||||
| 	(root)->sph_root = NULL;					\ | ||||
| } while (/*CONSTCOND*/ 0) | ||||
|  | ||||
| #define SPLAY_ENTRY(type)						\ | ||||
| struct {								\ | ||||
| 	struct type *spe_left; /* left element */			\ | ||||
| 	struct type *spe_right; /* right element */			\ | ||||
| } | ||||
|  | ||||
| #define SPLAY_LEFT(elm, field)		(elm)->field.spe_left | ||||
| #define SPLAY_RIGHT(elm, field)		(elm)->field.spe_right | ||||
| #define SPLAY_ROOT(head)		(head)->sph_root | ||||
| #define SPLAY_EMPTY(head)		(SPLAY_ROOT(head) == NULL) | ||||
|  | ||||
| /* SPLAY_ROTATE_{LEFT,RIGHT} expect that tmp hold SPLAY_{RIGHT,LEFT} */ | ||||
| #define SPLAY_ROTATE_RIGHT(head, tmp, field) do {			\ | ||||
| 	SPLAY_LEFT((head)->sph_root, field) = SPLAY_RIGHT(tmp, field);	\ | ||||
| 	SPLAY_RIGHT(tmp, field) = (head)->sph_root;			\ | ||||
| 	(head)->sph_root = tmp;						\ | ||||
| } while (/*CONSTCOND*/ 0) | ||||
| 	 | ||||
| #define SPLAY_ROTATE_LEFT(head, tmp, field) do {			\ | ||||
| 	SPLAY_RIGHT((head)->sph_root, field) = SPLAY_LEFT(tmp, field);	\ | ||||
| 	SPLAY_LEFT(tmp, field) = (head)->sph_root;			\ | ||||
| 	(head)->sph_root = tmp;						\ | ||||
| } while (/*CONSTCOND*/ 0) | ||||
|  | ||||
| #define SPLAY_LINKLEFT(head, tmp, field) do {				\ | ||||
| 	SPLAY_LEFT(tmp, field) = (head)->sph_root;			\ | ||||
| 	tmp = (head)->sph_root;						\ | ||||
| 	(head)->sph_root = SPLAY_LEFT((head)->sph_root, field);		\ | ||||
| } while (/*CONSTCOND*/ 0) | ||||
|  | ||||
| #define SPLAY_LINKRIGHT(head, tmp, field) do {				\ | ||||
| 	SPLAY_RIGHT(tmp, field) = (head)->sph_root;			\ | ||||
| 	tmp = (head)->sph_root;						\ | ||||
| 	(head)->sph_root = SPLAY_RIGHT((head)->sph_root, field);	\ | ||||
| } while (/*CONSTCOND*/ 0) | ||||
|  | ||||
| #define SPLAY_ASSEMBLE(head, node, left, right, field) do {		\ | ||||
| 	SPLAY_RIGHT(left, field) = SPLAY_LEFT((head)->sph_root, field);	\ | ||||
| 	SPLAY_LEFT(right, field) = SPLAY_RIGHT((head)->sph_root, field);\ | ||||
| 	SPLAY_LEFT((head)->sph_root, field) = SPLAY_RIGHT(node, field);	\ | ||||
| 	SPLAY_RIGHT((head)->sph_root, field) = SPLAY_LEFT(node, field);	\ | ||||
| } while (/*CONSTCOND*/ 0) | ||||
|  | ||||
| /* Generates prototypes and inline functions */ | ||||
|  | ||||
| #define SPLAY_PROTOTYPE(name, type, field, cmp)				\ | ||||
| void name##_SPLAY(struct name *, struct type *);			\ | ||||
| void name##_SPLAY_MINMAX(struct name *, int);				\ | ||||
| struct type *name##_SPLAY_INSERT(struct name *, struct type *);		\ | ||||
| struct type *name##_SPLAY_REMOVE(struct name *, struct type *);		\ | ||||
| 									\ | ||||
| /* Finds the node with the same key as elm */				\ | ||||
| static __inline struct type *						\ | ||||
| name##_SPLAY_FIND(struct name *head, struct type *elm)			\ | ||||
| {									\ | ||||
| 	if (SPLAY_EMPTY(head))						\ | ||||
| 		return(NULL);						\ | ||||
| 	name##_SPLAY(head, elm);					\ | ||||
| 	if ((cmp)(elm, (head)->sph_root) == 0)				\ | ||||
| 		return (head->sph_root);				\ | ||||
| 	return (NULL);							\ | ||||
| }									\ | ||||
| 									\ | ||||
| static __inline struct type *						\ | ||||
| name##_SPLAY_NEXT(struct name *head, struct type *elm)			\ | ||||
| {									\ | ||||
| 	name##_SPLAY(head, elm);					\ | ||||
| 	if (SPLAY_RIGHT(elm, field) != NULL) {				\ | ||||
| 		elm = SPLAY_RIGHT(elm, field);				\ | ||||
| 		while (SPLAY_LEFT(elm, field) != NULL) {		\ | ||||
| 			elm = SPLAY_LEFT(elm, field);			\ | ||||
| 		}							\ | ||||
| 	} else								\ | ||||
| 		elm = NULL;						\ | ||||
| 	return (elm);							\ | ||||
| }									\ | ||||
| 									\ | ||||
| static __inline struct type *						\ | ||||
| name##_SPLAY_MIN_MAX(struct name *head, int val)			\ | ||||
| {									\ | ||||
| 	name##_SPLAY_MINMAX(head, val);					\ | ||||
|         return (SPLAY_ROOT(head));					\ | ||||
| } | ||||
|  | ||||
| /* Main splay operation. | ||||
|  * Moves node close to the key of elm to top | ||||
|  */ | ||||
| #define SPLAY_GENERATE(name, type, field, cmp)				\ | ||||
| struct type *								\ | ||||
| name##_SPLAY_INSERT(struct name *head, struct type *elm)		\ | ||||
| {									\ | ||||
|     if (SPLAY_EMPTY(head)) {						\ | ||||
| 	    SPLAY_LEFT(elm, field) = SPLAY_RIGHT(elm, field) = NULL;	\ | ||||
|     } else {								\ | ||||
| 	    int __comp;							\ | ||||
| 	    name##_SPLAY(head, elm);					\ | ||||
| 	    __comp = (cmp)(elm, (head)->sph_root);			\ | ||||
| 	    if(__comp < 0) {						\ | ||||
| 		    SPLAY_LEFT(elm, field) = SPLAY_LEFT((head)->sph_root, field);\ | ||||
| 		    SPLAY_RIGHT(elm, field) = (head)->sph_root;		\ | ||||
| 		    SPLAY_LEFT((head)->sph_root, field) = NULL;		\ | ||||
| 	    } else if (__comp > 0) {					\ | ||||
| 		    SPLAY_RIGHT(elm, field) = SPLAY_RIGHT((head)->sph_root, field);\ | ||||
| 		    SPLAY_LEFT(elm, field) = (head)->sph_root;		\ | ||||
| 		    SPLAY_RIGHT((head)->sph_root, field) = NULL;	\ | ||||
| 	    } else							\ | ||||
| 		    return ((head)->sph_root);				\ | ||||
|     }									\ | ||||
|     (head)->sph_root = (elm);						\ | ||||
|     return (NULL);							\ | ||||
| }									\ | ||||
| 									\ | ||||
| struct type *								\ | ||||
| name##_SPLAY_REMOVE(struct name *head, struct type *elm)		\ | ||||
| {									\ | ||||
| 	struct type *__tmp;						\ | ||||
| 	if (SPLAY_EMPTY(head))						\ | ||||
| 		return (NULL);						\ | ||||
| 	name##_SPLAY(head, elm);					\ | ||||
| 	if ((cmp)(elm, (head)->sph_root) == 0) {			\ | ||||
| 		if (SPLAY_LEFT((head)->sph_root, field) == NULL) {	\ | ||||
| 			(head)->sph_root = SPLAY_RIGHT((head)->sph_root, field);\ | ||||
| 		} else {						\ | ||||
| 			__tmp = SPLAY_RIGHT((head)->sph_root, field);	\ | ||||
| 			(head)->sph_root = SPLAY_LEFT((head)->sph_root, field);\ | ||||
| 			name##_SPLAY(head, elm);			\ | ||||
| 			SPLAY_RIGHT((head)->sph_root, field) = __tmp;	\ | ||||
| 		}							\ | ||||
| 		return (elm);						\ | ||||
| 	}								\ | ||||
| 	return (NULL);							\ | ||||
| }									\ | ||||
| 									\ | ||||
| void									\ | ||||
| name##_SPLAY(struct name *head, struct type *elm)			\ | ||||
| {									\ | ||||
| 	struct type __node, *__left, *__right, *__tmp;			\ | ||||
| 	int __comp;							\ | ||||
| \ | ||||
| 	SPLAY_LEFT(&__node, field) = SPLAY_RIGHT(&__node, field) = NULL;\ | ||||
| 	__left = __right = &__node;					\ | ||||
| \ | ||||
| 	while ((__comp = (cmp)(elm, (head)->sph_root)) != 0) {		\ | ||||
| 		if (__comp < 0) {					\ | ||||
| 			__tmp = SPLAY_LEFT((head)->sph_root, field);	\ | ||||
| 			if (__tmp == NULL)				\ | ||||
| 				break;					\ | ||||
| 			if ((cmp)(elm, __tmp) < 0){			\ | ||||
| 				SPLAY_ROTATE_RIGHT(head, __tmp, field);	\ | ||||
| 				if (SPLAY_LEFT((head)->sph_root, field) == NULL)\ | ||||
| 					break;				\ | ||||
| 			}						\ | ||||
| 			SPLAY_LINKLEFT(head, __right, field);		\ | ||||
| 		} else if (__comp > 0) {				\ | ||||
| 			__tmp = SPLAY_RIGHT((head)->sph_root, field);	\ | ||||
| 			if (__tmp == NULL)				\ | ||||
| 				break;					\ | ||||
| 			if ((cmp)(elm, __tmp) > 0){			\ | ||||
| 				SPLAY_ROTATE_LEFT(head, __tmp, field);	\ | ||||
| 				if (SPLAY_RIGHT((head)->sph_root, field) == NULL)\ | ||||
| 					break;				\ | ||||
| 			}						\ | ||||
| 			SPLAY_LINKRIGHT(head, __left, field);		\ | ||||
| 		}							\ | ||||
| 	}								\ | ||||
| 	SPLAY_ASSEMBLE(head, &__node, __left, __right, field);		\ | ||||
| }									\ | ||||
| 									\ | ||||
| /* Splay with either the minimum or the maximum element			\ | ||||
|  * Used to find minimum or maximum element in tree.			\ | ||||
|  */									\ | ||||
| void name##_SPLAY_MINMAX(struct name *head, int __comp) \ | ||||
| {									\ | ||||
| 	struct type __node, *__left, *__right, *__tmp;			\ | ||||
| \ | ||||
| 	SPLAY_LEFT(&__node, field) = SPLAY_RIGHT(&__node, field) = NULL;\ | ||||
| 	__left = __right = &__node;					\ | ||||
| \ | ||||
| 	while (1) {							\ | ||||
| 		if (__comp < 0) {					\ | ||||
| 			__tmp = SPLAY_LEFT((head)->sph_root, field);	\ | ||||
| 			if (__tmp == NULL)				\ | ||||
| 				break;					\ | ||||
| 			if (__comp < 0){				\ | ||||
| 				SPLAY_ROTATE_RIGHT(head, __tmp, field);	\ | ||||
| 				if (SPLAY_LEFT((head)->sph_root, field) == NULL)\ | ||||
| 					break;				\ | ||||
| 			}						\ | ||||
| 			SPLAY_LINKLEFT(head, __right, field);		\ | ||||
| 		} else if (__comp > 0) {				\ | ||||
| 			__tmp = SPLAY_RIGHT((head)->sph_root, field);	\ | ||||
| 			if (__tmp == NULL)				\ | ||||
| 				break;					\ | ||||
| 			if (__comp > 0) {				\ | ||||
| 				SPLAY_ROTATE_LEFT(head, __tmp, field);	\ | ||||
| 				if (SPLAY_RIGHT((head)->sph_root, field) == NULL)\ | ||||
| 					break;				\ | ||||
| 			}						\ | ||||
| 			SPLAY_LINKRIGHT(head, __left, field);		\ | ||||
| 		}							\ | ||||
| 	}								\ | ||||
| 	SPLAY_ASSEMBLE(head, &__node, __left, __right, field);		\ | ||||
| } | ||||
|  | ||||
| #define SPLAY_NEGINF	-1 | ||||
| #define SPLAY_INF	1 | ||||
|  | ||||
| #define SPLAY_INSERT(name, x, y)	name##_SPLAY_INSERT(x, y) | ||||
| #define SPLAY_REMOVE(name, x, y)	name##_SPLAY_REMOVE(x, y) | ||||
| #define SPLAY_FIND(name, x, y)		name##_SPLAY_FIND(x, y) | ||||
| #define SPLAY_NEXT(name, x, y)		name##_SPLAY_NEXT(x, y) | ||||
| #define SPLAY_MIN(name, x)		(SPLAY_EMPTY(x) ? NULL	\ | ||||
| 					: name##_SPLAY_MIN_MAX(x, SPLAY_NEGINF)) | ||||
| #define SPLAY_MAX(name, x)		(SPLAY_EMPTY(x) ? NULL	\ | ||||
| 					: name##_SPLAY_MIN_MAX(x, SPLAY_INF)) | ||||
|  | ||||
| #define SPLAY_FOREACH(x, name, head)					\ | ||||
| 	for ((x) = SPLAY_MIN(name, head);				\ | ||||
| 	     (x) != NULL;						\ | ||||
| 	     (x) = SPLAY_NEXT(name, head, x)) | ||||
|  | ||||
| /* Macros that define a red-black tree */ | ||||
| #define RB_HEAD(name, type)						\ | ||||
| struct name {								\ | ||||
| 	struct type *rbh_root; /* root of the tree */			\ | ||||
| } | ||||
|  | ||||
| #define RB_INITIALIZER(root)						\ | ||||
| 	{ NULL } | ||||
|  | ||||
| #define RB_INIT(root) do {						\ | ||||
| 	(root)->rbh_root = NULL;					\ | ||||
| } while (/*CONSTCOND*/ 0) | ||||
|  | ||||
| #define RB_BLACK	0 | ||||
| #define RB_RED		1 | ||||
| #define RB_ENTRY(type)							\ | ||||
| struct {								\ | ||||
| 	struct type *rbe_left;		/* left element */		\ | ||||
| 	struct type *rbe_right;		/* right element */		\ | ||||
| 	struct type *rbe_parent;	/* parent element */		\ | ||||
| 	int rbe_color;			/* node color */		\ | ||||
| } | ||||
|  | ||||
| #define RB_LEFT(elm, field)		(elm)->field.rbe_left | ||||
| #define RB_RIGHT(elm, field)		(elm)->field.rbe_right | ||||
| #define RB_PARENT(elm, field)		(elm)->field.rbe_parent | ||||
| #define RB_COLOR(elm, field)		(elm)->field.rbe_color | ||||
| #define RB_ROOT(head)			(head)->rbh_root | ||||
| #define RB_EMPTY(head)			(RB_ROOT(head) == NULL) | ||||
|  | ||||
| #define RB_SET(elm, parent, field) do {					\ | ||||
| 	RB_PARENT(elm, field) = parent;					\ | ||||
| 	RB_LEFT(elm, field) = RB_RIGHT(elm, field) = NULL;		\ | ||||
| 	RB_COLOR(elm, field) = RB_RED;					\ | ||||
| } while (/*CONSTCOND*/ 0) | ||||
|  | ||||
| #define RB_SET_BLACKRED(black, red, field) do {				\ | ||||
| 	RB_COLOR(black, field) = RB_BLACK;				\ | ||||
| 	RB_COLOR(red, field) = RB_RED;					\ | ||||
| } while (/*CONSTCOND*/ 0) | ||||
|  | ||||
| #ifndef RB_AUGMENT | ||||
| #define RB_AUGMENT(x)	do {} while (0) | ||||
| #endif | ||||
|  | ||||
| #define RB_ROTATE_LEFT(head, elm, tmp, field) do {			\ | ||||
| 	(tmp) = RB_RIGHT(elm, field);					\ | ||||
| 	if ((RB_RIGHT(elm, field) = RB_LEFT(tmp, field)) != NULL) {	\ | ||||
| 		RB_PARENT(RB_LEFT(tmp, field), field) = (elm);		\ | ||||
| 	}								\ | ||||
| 	RB_AUGMENT(elm);						\ | ||||
| 	if ((RB_PARENT(tmp, field) = RB_PARENT(elm, field)) != NULL) {	\ | ||||
| 		if ((elm) == RB_LEFT(RB_PARENT(elm, field), field))	\ | ||||
| 			RB_LEFT(RB_PARENT(elm, field), field) = (tmp);	\ | ||||
| 		else							\ | ||||
| 			RB_RIGHT(RB_PARENT(elm, field), field) = (tmp);	\ | ||||
| 	} else								\ | ||||
| 		(head)->rbh_root = (tmp);				\ | ||||
| 	RB_LEFT(tmp, field) = (elm);					\ | ||||
| 	RB_PARENT(elm, field) = (tmp);					\ | ||||
| 	RB_AUGMENT(tmp);						\ | ||||
| 	if ((RB_PARENT(tmp, field)))					\ | ||||
| 		RB_AUGMENT(RB_PARENT(tmp, field));			\ | ||||
| } while (/*CONSTCOND*/ 0) | ||||
|  | ||||
| #define RB_ROTATE_RIGHT(head, elm, tmp, field) do {			\ | ||||
| 	(tmp) = RB_LEFT(elm, field);					\ | ||||
| 	if ((RB_LEFT(elm, field) = RB_RIGHT(tmp, field)) != NULL) {	\ | ||||
| 		RB_PARENT(RB_RIGHT(tmp, field), field) = (elm);		\ | ||||
| 	}								\ | ||||
| 	RB_AUGMENT(elm);						\ | ||||
| 	if ((RB_PARENT(tmp, field) = RB_PARENT(elm, field)) != NULL) {	\ | ||||
| 		if ((elm) == RB_LEFT(RB_PARENT(elm, field), field))	\ | ||||
| 			RB_LEFT(RB_PARENT(elm, field), field) = (tmp);	\ | ||||
| 		else							\ | ||||
| 			RB_RIGHT(RB_PARENT(elm, field), field) = (tmp);	\ | ||||
| 	} else								\ | ||||
| 		(head)->rbh_root = (tmp);				\ | ||||
| 	RB_RIGHT(tmp, field) = (elm);					\ | ||||
| 	RB_PARENT(elm, field) = (tmp);					\ | ||||
| 	RB_AUGMENT(tmp);						\ | ||||
| 	if ((RB_PARENT(tmp, field)))					\ | ||||
| 		RB_AUGMENT(RB_PARENT(tmp, field));			\ | ||||
| } while (/*CONSTCOND*/ 0) | ||||
|  | ||||
| /* Generates prototypes and inline functions */ | ||||
| #define	RB_PROTOTYPE(name, type, field, cmp)				\ | ||||
| 	RB_PROTOTYPE_INTERNAL(name, type, field, cmp,) | ||||
| #define	RB_PROTOTYPE_STATIC(name, type, field, cmp)			\ | ||||
| 	RB_PROTOTYPE_INTERNAL(name, type, field, cmp, __unused static) | ||||
| #define RB_PROTOTYPE_INTERNAL(name, type, field, cmp, attr)		\ | ||||
| attr void name##_RB_INSERT_COLOR(struct name *, struct type *);		\ | ||||
| attr void name##_RB_REMOVE_COLOR(struct name *, struct type *, struct type *);\ | ||||
| attr struct type *name##_RB_REMOVE(struct name *, struct type *);	\ | ||||
| attr struct type *name##_RB_INSERT(struct name *, struct type *);	\ | ||||
| attr struct type *name##_RB_FIND(struct name *, struct type *);		\ | ||||
| attr struct type *name##_RB_NFIND(struct name *, struct type *);	\ | ||||
| attr struct type *name##_RB_NEXT(struct type *);			\ | ||||
| attr struct type *name##_RB_PREV(struct type *);			\ | ||||
| attr struct type *name##_RB_MINMAX(struct name *, int);			\ | ||||
| 									\ | ||||
|  | ||||
| /* Main rb operation. | ||||
|  * Moves node close to the key of elm to top | ||||
|  */ | ||||
| #define	RB_GENERATE(name, type, field, cmp)				\ | ||||
| 	RB_GENERATE_INTERNAL(name, type, field, cmp,) | ||||
| #define	RB_GENERATE_STATIC(name, type, field, cmp)			\ | ||||
| 	RB_GENERATE_INTERNAL(name, type, field, cmp, __unused static) | ||||
| #define RB_GENERATE_INTERNAL(name, type, field, cmp, attr)		\ | ||||
| attr void								\ | ||||
| name##_RB_INSERT_COLOR(struct name *head, struct type *elm)		\ | ||||
| {									\ | ||||
| 	struct type *parent, *gparent, *tmp;				\ | ||||
| 	while ((parent = RB_PARENT(elm, field)) != NULL &&		\ | ||||
| 	    RB_COLOR(parent, field) == RB_RED) {			\ | ||||
| 		gparent = RB_PARENT(parent, field);			\ | ||||
| 		if (parent == RB_LEFT(gparent, field)) {		\ | ||||
| 			tmp = RB_RIGHT(gparent, field);			\ | ||||
| 			if (tmp && RB_COLOR(tmp, field) == RB_RED) {	\ | ||||
| 				RB_COLOR(tmp, field) = RB_BLACK;	\ | ||||
| 				RB_SET_BLACKRED(parent, gparent, field);\ | ||||
| 				elm = gparent;				\ | ||||
| 				continue;				\ | ||||
| 			}						\ | ||||
| 			if (RB_RIGHT(parent, field) == elm) {		\ | ||||
| 				RB_ROTATE_LEFT(head, parent, tmp, field);\ | ||||
| 				tmp = parent;				\ | ||||
| 				parent = elm;				\ | ||||
| 				elm = tmp;				\ | ||||
| 			}						\ | ||||
| 			RB_SET_BLACKRED(parent, gparent, field);	\ | ||||
| 			RB_ROTATE_RIGHT(head, gparent, tmp, field);	\ | ||||
| 		} else {						\ | ||||
| 			tmp = RB_LEFT(gparent, field);			\ | ||||
| 			if (tmp && RB_COLOR(tmp, field) == RB_RED) {	\ | ||||
| 				RB_COLOR(tmp, field) = RB_BLACK;	\ | ||||
| 				RB_SET_BLACKRED(parent, gparent, field);\ | ||||
| 				elm = gparent;				\ | ||||
| 				continue;				\ | ||||
| 			}						\ | ||||
| 			if (RB_LEFT(parent, field) == elm) {		\ | ||||
| 				RB_ROTATE_RIGHT(head, parent, tmp, field);\ | ||||
| 				tmp = parent;				\ | ||||
| 				parent = elm;				\ | ||||
| 				elm = tmp;				\ | ||||
| 			}						\ | ||||
| 			RB_SET_BLACKRED(parent, gparent, field);	\ | ||||
| 			RB_ROTATE_LEFT(head, gparent, tmp, field);	\ | ||||
| 		}							\ | ||||
| 	}								\ | ||||
| 	RB_COLOR(head->rbh_root, field) = RB_BLACK;			\ | ||||
| }									\ | ||||
| 									\ | ||||
| attr void								\ | ||||
| name##_RB_REMOVE_COLOR(struct name *head, struct type *parent, struct type *elm) \ | ||||
| {									\ | ||||
| 	struct type *tmp;						\ | ||||
| 	while ((elm == NULL || RB_COLOR(elm, field) == RB_BLACK) &&	\ | ||||
| 	    elm != RB_ROOT(head)) {					\ | ||||
| 		if (RB_LEFT(parent, field) == elm) {			\ | ||||
| 			tmp = RB_RIGHT(parent, field);			\ | ||||
| 			if (RB_COLOR(tmp, field) == RB_RED) {		\ | ||||
| 				RB_SET_BLACKRED(tmp, parent, field);	\ | ||||
| 				RB_ROTATE_LEFT(head, parent, tmp, field);\ | ||||
| 				tmp = RB_RIGHT(parent, field);		\ | ||||
| 			}						\ | ||||
| 			if ((RB_LEFT(tmp, field) == NULL ||		\ | ||||
| 			    RB_COLOR(RB_LEFT(tmp, field), field) == RB_BLACK) &&\ | ||||
| 			    (RB_RIGHT(tmp, field) == NULL ||		\ | ||||
| 			    RB_COLOR(RB_RIGHT(tmp, field), field) == RB_BLACK)) {\ | ||||
| 				RB_COLOR(tmp, field) = RB_RED;		\ | ||||
| 				elm = parent;				\ | ||||
| 				parent = RB_PARENT(elm, field);		\ | ||||
| 			} else {					\ | ||||
| 				if (RB_RIGHT(tmp, field) == NULL ||	\ | ||||
| 				    RB_COLOR(RB_RIGHT(tmp, field), field) == RB_BLACK) {\ | ||||
| 					struct type *oleft;		\ | ||||
| 					if ((oleft = RB_LEFT(tmp, field)) \ | ||||
| 					    != NULL)			\ | ||||
| 						RB_COLOR(oleft, field) = RB_BLACK;\ | ||||
| 					RB_COLOR(tmp, field) = RB_RED;	\ | ||||
| 					RB_ROTATE_RIGHT(head, tmp, oleft, field);\ | ||||
| 					tmp = RB_RIGHT(parent, field);	\ | ||||
| 				}					\ | ||||
| 				RB_COLOR(tmp, field) = RB_COLOR(parent, field);\ | ||||
| 				RB_COLOR(parent, field) = RB_BLACK;	\ | ||||
| 				if (RB_RIGHT(tmp, field))		\ | ||||
| 					RB_COLOR(RB_RIGHT(tmp, field), field) = RB_BLACK;\ | ||||
| 				RB_ROTATE_LEFT(head, parent, tmp, field);\ | ||||
| 				elm = RB_ROOT(head);			\ | ||||
| 				break;					\ | ||||
| 			}						\ | ||||
| 		} else {						\ | ||||
| 			tmp = RB_LEFT(parent, field);			\ | ||||
| 			if (RB_COLOR(tmp, field) == RB_RED) {		\ | ||||
| 				RB_SET_BLACKRED(tmp, parent, field);	\ | ||||
| 				RB_ROTATE_RIGHT(head, parent, tmp, field);\ | ||||
| 				tmp = RB_LEFT(parent, field);		\ | ||||
| 			}						\ | ||||
| 			if ((RB_LEFT(tmp, field) == NULL ||		\ | ||||
| 			    RB_COLOR(RB_LEFT(tmp, field), field) == RB_BLACK) &&\ | ||||
| 			    (RB_RIGHT(tmp, field) == NULL ||		\ | ||||
| 			    RB_COLOR(RB_RIGHT(tmp, field), field) == RB_BLACK)) {\ | ||||
| 				RB_COLOR(tmp, field) = RB_RED;		\ | ||||
| 				elm = parent;				\ | ||||
| 				parent = RB_PARENT(elm, field);		\ | ||||
| 			} else {					\ | ||||
| 				if (RB_LEFT(tmp, field) == NULL ||	\ | ||||
| 				    RB_COLOR(RB_LEFT(tmp, field), field) == RB_BLACK) {\ | ||||
| 					struct type *oright;		\ | ||||
| 					if ((oright = RB_RIGHT(tmp, field)) \ | ||||
| 					    != NULL)			\ | ||||
| 						RB_COLOR(oright, field) = RB_BLACK;\ | ||||
| 					RB_COLOR(tmp, field) = RB_RED;	\ | ||||
| 					RB_ROTATE_LEFT(head, tmp, oright, field);\ | ||||
| 					tmp = RB_LEFT(parent, field);	\ | ||||
| 				}					\ | ||||
| 				RB_COLOR(tmp, field) = RB_COLOR(parent, field);\ | ||||
| 				RB_COLOR(parent, field) = RB_BLACK;	\ | ||||
| 				if (RB_LEFT(tmp, field))		\ | ||||
| 					RB_COLOR(RB_LEFT(tmp, field), field) = RB_BLACK;\ | ||||
| 				RB_ROTATE_RIGHT(head, parent, tmp, field);\ | ||||
| 				elm = RB_ROOT(head);			\ | ||||
| 				break;					\ | ||||
| 			}						\ | ||||
| 		}							\ | ||||
| 	}								\ | ||||
| 	if (elm)							\ | ||||
| 		RB_COLOR(elm, field) = RB_BLACK;			\ | ||||
| }									\ | ||||
| 									\ | ||||
| attr struct type *							\ | ||||
| name##_RB_REMOVE(struct name *head, struct type *elm)			\ | ||||
| {									\ | ||||
| 	struct type *child, *parent, *old = elm;			\ | ||||
| 	int color;							\ | ||||
| 	if (RB_LEFT(elm, field) == NULL)				\ | ||||
| 		child = RB_RIGHT(elm, field);				\ | ||||
| 	else if (RB_RIGHT(elm, field) == NULL)				\ | ||||
| 		child = RB_LEFT(elm, field);				\ | ||||
| 	else {								\ | ||||
| 		struct type *left;					\ | ||||
| 		elm = RB_RIGHT(elm, field);				\ | ||||
| 		while ((left = RB_LEFT(elm, field)) != NULL)		\ | ||||
| 			elm = left;					\ | ||||
| 		child = RB_RIGHT(elm, field);				\ | ||||
| 		parent = RB_PARENT(elm, field);				\ | ||||
| 		color = RB_COLOR(elm, field);				\ | ||||
| 		if (child)						\ | ||||
| 			RB_PARENT(child, field) = parent;		\ | ||||
| 		if (parent) {						\ | ||||
| 			if (RB_LEFT(parent, field) == elm)		\ | ||||
| 				RB_LEFT(parent, field) = child;		\ | ||||
| 			else						\ | ||||
| 				RB_RIGHT(parent, field) = child;	\ | ||||
| 			RB_AUGMENT(parent);				\ | ||||
| 		} else							\ | ||||
| 			RB_ROOT(head) = child;				\ | ||||
| 		if (RB_PARENT(elm, field) == old)			\ | ||||
| 			parent = elm;					\ | ||||
| 		(elm)->field = (old)->field;				\ | ||||
| 		if (RB_PARENT(old, field)) {				\ | ||||
| 			if (RB_LEFT(RB_PARENT(old, field), field) == old)\ | ||||
| 				RB_LEFT(RB_PARENT(old, field), field) = elm;\ | ||||
| 			else						\ | ||||
| 				RB_RIGHT(RB_PARENT(old, field), field) = elm;\ | ||||
| 			RB_AUGMENT(RB_PARENT(old, field));		\ | ||||
| 		} else							\ | ||||
| 			RB_ROOT(head) = elm;				\ | ||||
| 		RB_PARENT(RB_LEFT(old, field), field) = elm;		\ | ||||
| 		if (RB_RIGHT(old, field))				\ | ||||
| 			RB_PARENT(RB_RIGHT(old, field), field) = elm;	\ | ||||
| 		if (parent) {						\ | ||||
| 			left = parent;					\ | ||||
| 			do {						\ | ||||
| 				RB_AUGMENT(left);			\ | ||||
| 			} while ((left = RB_PARENT(left, field)) != NULL); \ | ||||
| 		}							\ | ||||
| 		goto color;						\ | ||||
| 	}								\ | ||||
| 	parent = RB_PARENT(elm, field);					\ | ||||
| 	color = RB_COLOR(elm, field);					\ | ||||
| 	if (child)							\ | ||||
| 		RB_PARENT(child, field) = parent;			\ | ||||
| 	if (parent) {							\ | ||||
| 		if (RB_LEFT(parent, field) == elm)			\ | ||||
| 			RB_LEFT(parent, field) = child;			\ | ||||
| 		else							\ | ||||
| 			RB_RIGHT(parent, field) = child;		\ | ||||
| 		RB_AUGMENT(parent);					\ | ||||
| 	} else								\ | ||||
| 		RB_ROOT(head) = child;					\ | ||||
| color:									\ | ||||
| 	if (color == RB_BLACK)						\ | ||||
| 		name##_RB_REMOVE_COLOR(head, parent, child);		\ | ||||
| 	return (old);							\ | ||||
| }									\ | ||||
| 									\ | ||||
| /* Inserts a node into the RB tree */					\ | ||||
| attr struct type *							\ | ||||
| name##_RB_INSERT(struct name *head, struct type *elm)			\ | ||||
| {									\ | ||||
| 	struct type *tmp;						\ | ||||
| 	struct type *parent = NULL;					\ | ||||
| 	int comp = 0;							\ | ||||
| 	tmp = RB_ROOT(head);						\ | ||||
| 	while (tmp) {							\ | ||||
| 		parent = tmp;						\ | ||||
| 		comp = (cmp)(elm, parent);				\ | ||||
| 		if (comp < 0)						\ | ||||
| 			tmp = RB_LEFT(tmp, field);			\ | ||||
| 		else if (comp > 0)					\ | ||||
| 			tmp = RB_RIGHT(tmp, field);			\ | ||||
| 		else							\ | ||||
| 			return (tmp);					\ | ||||
| 	}								\ | ||||
| 	RB_SET(elm, parent, field);					\ | ||||
| 	if (parent != NULL) {						\ | ||||
| 		if (comp < 0)						\ | ||||
| 			RB_LEFT(parent, field) = elm;			\ | ||||
| 		else							\ | ||||
| 			RB_RIGHT(parent, field) = elm;			\ | ||||
| 		RB_AUGMENT(parent);					\ | ||||
| 	} else								\ | ||||
| 		RB_ROOT(head) = elm;					\ | ||||
| 	name##_RB_INSERT_COLOR(head, elm);				\ | ||||
| 	return (NULL);							\ | ||||
| }									\ | ||||
| 									\ | ||||
| /* Finds the node with the same key as elm */				\ | ||||
| attr struct type *							\ | ||||
| name##_RB_FIND(struct name *head, struct type *elm)			\ | ||||
| {									\ | ||||
| 	struct type *tmp = RB_ROOT(head);				\ | ||||
| 	int comp;							\ | ||||
| 	while (tmp) {							\ | ||||
| 		comp = cmp(elm, tmp);					\ | ||||
| 		if (comp < 0)						\ | ||||
| 			tmp = RB_LEFT(tmp, field);			\ | ||||
| 		else if (comp > 0)					\ | ||||
| 			tmp = RB_RIGHT(tmp, field);			\ | ||||
| 		else							\ | ||||
| 			return (tmp);					\ | ||||
| 	}								\ | ||||
| 	return (NULL);							\ | ||||
| }									\ | ||||
| 									\ | ||||
| /* Finds the first node greater than or equal to the search key */	\ | ||||
| attr struct type *							\ | ||||
| name##_RB_NFIND(struct name *head, struct type *elm)			\ | ||||
| {									\ | ||||
| 	struct type *tmp = RB_ROOT(head);				\ | ||||
| 	struct type *res = NULL;					\ | ||||
| 	int comp;							\ | ||||
| 	while (tmp) {							\ | ||||
| 		comp = cmp(elm, tmp);					\ | ||||
| 		if (comp < 0) {						\ | ||||
| 			res = tmp;					\ | ||||
| 			tmp = RB_LEFT(tmp, field);			\ | ||||
| 		}							\ | ||||
| 		else if (comp > 0)					\ | ||||
| 			tmp = RB_RIGHT(tmp, field);			\ | ||||
| 		else							\ | ||||
| 			return (tmp);					\ | ||||
| 	}								\ | ||||
| 	return (res);							\ | ||||
| }									\ | ||||
| 									\ | ||||
| /* ARGSUSED */								\ | ||||
| attr struct type *							\ | ||||
| name##_RB_NEXT(struct type *elm)					\ | ||||
| {									\ | ||||
| 	if (RB_RIGHT(elm, field)) {					\ | ||||
| 		elm = RB_RIGHT(elm, field);				\ | ||||
| 		while (RB_LEFT(elm, field))				\ | ||||
| 			elm = RB_LEFT(elm, field);			\ | ||||
| 	} else {							\ | ||||
| 		if (RB_PARENT(elm, field) &&				\ | ||||
| 		    (elm == RB_LEFT(RB_PARENT(elm, field), field)))	\ | ||||
| 			elm = RB_PARENT(elm, field);			\ | ||||
| 		else {							\ | ||||
| 			while (RB_PARENT(elm, field) &&			\ | ||||
| 			    (elm == RB_RIGHT(RB_PARENT(elm, field), field)))\ | ||||
| 				elm = RB_PARENT(elm, field);		\ | ||||
| 			elm = RB_PARENT(elm, field);			\ | ||||
| 		}							\ | ||||
| 	}								\ | ||||
| 	return (elm);							\ | ||||
| }									\ | ||||
| 									\ | ||||
| /* ARGSUSED */								\ | ||||
| attr struct type *							\ | ||||
| name##_RB_PREV(struct type *elm)					\ | ||||
| {									\ | ||||
| 	if (RB_LEFT(elm, field)) {					\ | ||||
| 		elm = RB_LEFT(elm, field);				\ | ||||
| 		while (RB_RIGHT(elm, field))				\ | ||||
| 			elm = RB_RIGHT(elm, field);			\ | ||||
| 	} else {							\ | ||||
| 		if (RB_PARENT(elm, field) &&				\ | ||||
| 		    (elm == RB_RIGHT(RB_PARENT(elm, field), field)))	\ | ||||
| 			elm = RB_PARENT(elm, field);			\ | ||||
| 		else {							\ | ||||
| 			while (RB_PARENT(elm, field) &&			\ | ||||
| 			    (elm == RB_LEFT(RB_PARENT(elm, field), field)))\ | ||||
| 				elm = RB_PARENT(elm, field);		\ | ||||
| 			elm = RB_PARENT(elm, field);			\ | ||||
| 		}							\ | ||||
| 	}								\ | ||||
| 	return (elm);							\ | ||||
| }									\ | ||||
| 									\ | ||||
| attr struct type *							\ | ||||
| name##_RB_MINMAX(struct name *head, int val)				\ | ||||
| {									\ | ||||
| 	struct type *tmp = RB_ROOT(head);				\ | ||||
| 	struct type *parent = NULL;					\ | ||||
| 	while (tmp) {							\ | ||||
| 		parent = tmp;						\ | ||||
| 		if (val < 0)						\ | ||||
| 			tmp = RB_LEFT(tmp, field);			\ | ||||
| 		else							\ | ||||
| 			tmp = RB_RIGHT(tmp, field);			\ | ||||
| 	}								\ | ||||
| 	return (parent);						\ | ||||
| } | ||||
|  | ||||
| #define RB_NEGINF	-1 | ||||
| #define RB_INF	1 | ||||
|  | ||||
| #define RB_INSERT(name, x, y)	name##_RB_INSERT(x, y) | ||||
| #define RB_REMOVE(name, x, y)	name##_RB_REMOVE(x, y) | ||||
| #define RB_FIND(name, x, y)	name##_RB_FIND(x, y) | ||||
| #define RB_NFIND(name, x, y)	name##_RB_NFIND(x, y) | ||||
| #define RB_NEXT(name, x, y)	name##_RB_NEXT(y) | ||||
| #define RB_PREV(name, x, y)	name##_RB_PREV(y) | ||||
| #define RB_MIN(name, x)		name##_RB_MINMAX(x, RB_NEGINF) | ||||
| #define RB_MAX(name, x)		name##_RB_MINMAX(x, RB_INF) | ||||
|  | ||||
| #define RB_FOREACH(x, name, head)					\ | ||||
| 	for ((x) = RB_MIN(name, head);					\ | ||||
| 	     (x) != NULL;						\ | ||||
| 	     (x) = name##_RB_NEXT(x)) | ||||
|  | ||||
| #define RB_FOREACH_FROM(x, name, y)					\ | ||||
| 	for ((x) = (y);							\ | ||||
| 	    ((x) != NULL) && ((y) = name##_RB_NEXT(x), (x) != NULL);	\ | ||||
| 	     (x) = (y)) | ||||
|  | ||||
| #define RB_FOREACH_SAFE(x, name, head, y)				\ | ||||
| 	for ((x) = RB_MIN(name, head);					\ | ||||
| 	    ((x) != NULL) && ((y) = name##_RB_NEXT(x), (x) != NULL);	\ | ||||
| 	     (x) = (y)) | ||||
|  | ||||
| #define RB_FOREACH_REVERSE(x, name, head)				\ | ||||
| 	for ((x) = RB_MAX(name, head);					\ | ||||
| 	     (x) != NULL;						\ | ||||
| 	     (x) = name##_RB_PREV(x)) | ||||
|  | ||||
| #define RB_FOREACH_REVERSE_FROM(x, name, y)				\ | ||||
| 	for ((x) = (y);							\ | ||||
| 	    ((x) != NULL) && ((y) = name##_RB_PREV(x), (x) != NULL);	\ | ||||
| 	     (x) = (y)) | ||||
|  | ||||
| #define RB_FOREACH_REVERSE_SAFE(x, name, head, y)			\ | ||||
| 	for ((x) = RB_MAX(name, head);					\ | ||||
| 	    ((x) != NULL) && ((y) = name##_RB_PREV(x), (x) != NULL);	\ | ||||
| 	     (x) = (y)) | ||||
|  | ||||
| #endif	/* _SYS_TREE_H_ */ | ||||
| @@ -1,5 +1,6 @@ | ||||
| /*
 | ||||
|  * Copyright © 2004, 2005, 2006, 2009 Guillem Jover | ||||
|  * Copyright © 2006 Robert Millan | ||||
|  * Copyright © 2008-2011 Guillem Jover <guillem@hadrons.org> | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
|  * modification, are permitted provided that the following conditions | ||||
| @@ -24,69 +25,40 @@ | ||||
|  * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  */ | ||||
| 
 | ||||
| #ifndef LIBBSD_CDEFS_H | ||||
| #define LIBBSD_CDEFS_H | ||||
| #ifdef LIBBSD_OVERLAY | ||||
| #include_next <unistd.h> | ||||
| #else | ||||
| #include <unistd.h> | ||||
| #endif | ||||
| 
 | ||||
| #ifndef LIBBSD_UNISTD_H | ||||
| #define LIBBSD_UNISTD_H | ||||
| 
 | ||||
| #include <sys/cdefs.h> | ||||
| #include <sys/stat.h> | ||||
| 
 | ||||
| #ifndef setproctitle | ||||
| # define setproctitle(fmt, args...) | ||||
| #ifndef S_ISTXT | ||||
| #define S_ISTXT S_ISVTX | ||||
| #endif | ||||
| 
 | ||||
| #ifndef __dead2 | ||||
| # define __dead2 | ||||
| __BEGIN_DECLS | ||||
| extern int optreset; | ||||
| 
 | ||||
| #ifdef LIBBSD_OVERLAY | ||||
| #undef getopt | ||||
| #define getopt(argc, argv, optstr) bsd_getopt(argc, argv, optstr) | ||||
| #endif | ||||
| 
 | ||||
| #ifndef __pure2 | ||||
| # define __pure2 | ||||
| #endif | ||||
| int bsd_getopt(int argc, char * const argv[], const char *shortopts); | ||||
| 
 | ||||
| /* Linux headers define a struct with a member names __unused.
 | ||||
|  * Disable for now. */ | ||||
| #if 0 | ||||
| #ifndef __unused | ||||
| # ifdef __GNUC__ | ||||
| #  define __unused __attribute__((unused)) | ||||
| # else | ||||
| #  define __unused | ||||
| # endif | ||||
| #endif | ||||
| #endif | ||||
| mode_t getmode(const void *set, mode_t mode); | ||||
| void *setmode(const char *mode_str); | ||||
| 
 | ||||
| #ifndef __printflike | ||||
| # ifdef __GNUC__ | ||||
| #  define __printflike(x, y) __attribute((format(printf, (x), (y)))) | ||||
| # else | ||||
| #  define __printflike(x, y) | ||||
| # endif | ||||
| #endif | ||||
| void closefrom(int lowfd); | ||||
| 
 | ||||
| #ifndef __bounded__ | ||||
| # define __bounded__(x, y, z) | ||||
| #endif | ||||
| void setproctitle(const char *fmt, ...); | ||||
| 
 | ||||
| #ifndef __RCSID | ||||
| # define __RCSID(x) | ||||
| #endif | ||||
| 
 | ||||
| #ifndef __FBSDID | ||||
| # define __FBSDID(x) | ||||
| #endif | ||||
| 
 | ||||
| #ifndef __RCSID | ||||
| # define __RCSID(x) | ||||
| #endif | ||||
| 
 | ||||
| #ifndef __RCSID_SOURCE | ||||
| # define __RCSID_SOURCE | ||||
| #endif | ||||
| 
 | ||||
| #ifndef __SCCSID | ||||
| # define __SCCSID | ||||
| #endif | ||||
| 
 | ||||
| #ifndef __COPYRIGHT | ||||
| # define __COPYRIGHT | ||||
| #endif | ||||
| int getpeereid(int s, uid_t *euid, gid_t *egid); | ||||
| __END_DECLS | ||||
| 
 | ||||
| #endif | ||||
| @@ -78,8 +78,10 @@ __BEGIN_DECLS | ||||
| char	*vis(char *, int, int, int); | ||||
| int	strvis(char *, const char *, int); | ||||
| int	strvisx(char *, const char *, size_t, int); | ||||
| int	strnvis(char *, const char *, size_t, int); | ||||
| int	strunvis(char *, const char *); | ||||
| int	strunvisx(char *, const char *, int); | ||||
| ssize_t strnunvis(char *, const char *, size_t); | ||||
| int	unvis(char *, int, int *, int); | ||||
| __END_DECLS | ||||
| 
 | ||||
							
								
								
									
										47
									
								
								include/bsd/wchar.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										47
									
								
								include/bsd/wchar.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,47 @@ | ||||
| /* | ||||
|  * Copyright © 2012 Guillem Jover <guillem@hadrons.org> | ||||
|  * | ||||
|  * 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. | ||||
|  */ | ||||
|  | ||||
| #ifdef LIBBSD_OVERLAY | ||||
| #include_next <wchar.h> | ||||
| #else | ||||
| #include <wchar.h> | ||||
| #endif | ||||
|  | ||||
| #ifndef LIBBSD_WCHAR_H | ||||
| #define LIBBSD_WCHAR_H | ||||
|  | ||||
| #include <stddef.h> | ||||
| #include <sys/cdefs.h> | ||||
| #include <sys/types.h> | ||||
|  | ||||
| __BEGIN_DECLS | ||||
| wchar_t *fgetwln(FILE *stream, size_t *len); | ||||
|  | ||||
| size_t wcslcat(wchar_t *dst, const wchar_t *src, size_t size); | ||||
| size_t wcslcpy(wchar_t *dst, const wchar_t *src, size_t size); | ||||
| __END_DECLS | ||||
|  | ||||
| #endif | ||||
							
								
								
									
										58
									
								
								man/Makefile.am
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								man/Makefile.am
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,58 @@ | ||||
| ## Process this file with automake to produce Makefile.in | ||||
|  | ||||
| EXTRA_DIST = \ | ||||
| 	mdX.3bsd \ | ||||
| 	$(nil) | ||||
|  | ||||
| CLEANFILES = \ | ||||
| 	md5.3bsd \ | ||||
| 	$(nil) | ||||
|  | ||||
| SED_MD5_SUBST = -e 's/mdX/md5/g' -e 's/mdY/md4/g' -e 's/MDX/MD5/g' | ||||
|  | ||||
| md5.3bsd: $(srcdir)/mdX.3bsd | ||||
| 	$(AM_V_GEN) sed $(SED_MD5_SUBST) $< > $@ | ||||
|  | ||||
| dist_man_MANS = \ | ||||
| 	arc4random.3 \ | ||||
| 	arc4random_addrandom.3 \ | ||||
| 	arc4random_buf.3 \ | ||||
| 	arc4random_stir.3 \ | ||||
| 	arc4random_uniform.3 \ | ||||
| 	bitstring.3 \ | ||||
| 	closefrom.3 \ | ||||
| 	dehumanize_number.3 \ | ||||
| 	expand_number.3 \ | ||||
| 	fgetln.3 \ | ||||
| 	fgetwln.3 \ | ||||
| 	flopen.3 \ | ||||
| 	fmtcheck.3 \ | ||||
| 	fparseln.3 \ | ||||
| 	getmode.3 \ | ||||
| 	getpeereid.3 \ | ||||
| 	getprogname.3 \ | ||||
| 	heapsort.3 \ | ||||
| 	humanize_number.3 \ | ||||
| 	md5.3bsd \ | ||||
| 	mergesort.3 \ | ||||
| 	nlist.3 \ | ||||
| 	pidfile.3 \ | ||||
| 	queue.3bsd \ | ||||
| 	radixsort.3 \ | ||||
| 	readpassphrase.3 \ | ||||
| 	reallocf.3 \ | ||||
| 	setmode.3 \ | ||||
| 	setproctitle.3 \ | ||||
| 	setprogname.3 \ | ||||
| 	sradixsort.3 \ | ||||
| 	strlcat.3 \ | ||||
| 	strlcpy.3 \ | ||||
| 	strnstr.3 \ | ||||
| 	strmode.3 \ | ||||
| 	strtonum.3 \ | ||||
| 	tree.3 \ | ||||
| 	unvis.3 \ | ||||
| 	vis.3 \ | ||||
| 	wcslcat.3 \ | ||||
| 	wcslcpy.3 \ | ||||
| 	$(nil) | ||||
| @@ -28,23 +28,30 @@ | ||||
| .\" THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
| .\" | ||||
| .\" Manual page, using -mandoc macros | ||||
| .\" $FreeBSD: /repoman/r/ncvs/src/lib/libc/gen/arc4random.3,v 1.16 2003/07/31 06:18:24 das Exp $ | ||||
| .\" $FreeBSD$ | ||||
| .\" | ||||
| .Dd April 15, 1997 | ||||
| .Dt ARC4RANDOM 3 | ||||
| .Os | ||||
| .Sh NAME | ||||
| .Nm arc4random , | ||||
| .Nm arc4random_buf , | ||||
| .Nm arc4random_uniform , | ||||
| .Nm arc4random_stir , | ||||
| .Nm arc4random_addrandom | ||||
| .Nd arc4 random number generator | ||||
| .Sh LIBRARY | ||||
| .Lb libc | ||||
| .ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd) | ||||
| .Lb libbsd | ||||
| .Sh SYNOPSIS | ||||
| .In stdlib.h | ||||
| .In bsd/stdlib.h | ||||
| .Ft u_int32_t | ||||
| .Fn arc4random "void" | ||||
| .Ft void | ||||
| .Fn arc4random_buf "void *buf" "size_t nbytes" | ||||
| .Ft u_int32_t | ||||
| .Fn arc4random_uniform "u_int32_t upper_bound" | ||||
| .Ft void | ||||
| .Fn arc4random_stir "void" | ||||
| .Ft void | ||||
| .Fn arc4random_addrandom "unsigned char *dat" "int datlen" | ||||
| @@ -68,6 +75,21 @@ and therefore has twice the range of | ||||
| and | ||||
| .Xr random 3 . | ||||
| .Pp | ||||
| .Fn arc4random_buf | ||||
| function fills the region | ||||
| .Fa buf | ||||
| of length | ||||
| .Fa nbytes | ||||
| with ARC4-derived random data. | ||||
| .Pp | ||||
| .Fn arc4random_uniform | ||||
| will return a uniformly distributed random number less than | ||||
| .Fa upper_bound . | ||||
| .Fn arc4random_uniform | ||||
| is recommended over constructions like | ||||
| .Dq Li arc4random() % upper_bound | ||||
| as it avoids "modulo bias" when the upper bound is not a power of two. | ||||
| .Pp | ||||
| The | ||||
| .Fn arc4random_stir | ||||
| function reads data from | ||||
| @@ -78,10 +100,9 @@ and uses it to permute the S-Boxes via | ||||
| There is no need to call | ||||
| .Fn arc4random_stir | ||||
| before using | ||||
| .Fn arc4random , | ||||
| since | ||||
| .Fn arc4random | ||||
| automatically initializes itself. | ||||
| functions family, since | ||||
| they automatically initialize themselves. | ||||
| .Sh EXAMPLES | ||||
| The following produces a drop-in replacement for the traditional | ||||
| .Fn rand | ||||
|   | ||||
							
								
								
									
										1
									
								
								man/arc4random_buf.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								man/arc4random_buf.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| .so man3/arc4random.3 | ||||
							
								
								
									
										1
									
								
								man/arc4random_uniform.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								man/arc4random_uniform.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| .so man3/arc4random.3 | ||||
							
								
								
									
										186
									
								
								man/bitstring.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										186
									
								
								man/bitstring.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,186 @@ | ||||
| .\" Copyright (c) 1989, 1991, 1993 | ||||
| .\"	The Regents of the University of California.  All rights reserved. | ||||
| .\" | ||||
| .\" This code is derived from software contributed to Berkeley by | ||||
| .\" Paul Vixie. | ||||
| .\" 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. | ||||
| .\" 4. Neither the name of the University nor the names of its contributors | ||||
| .\"    may be used to endorse or promote products derived from this software | ||||
| .\"    without specific prior written permission. | ||||
| .\" | ||||
| .\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``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 REGENTS OR CONTRIBUTORS 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. | ||||
| .\" | ||||
| .\"     @(#)bitstring.3	8.1 (Berkeley) 7/19/93 | ||||
| .\" $FreeBSD$ | ||||
| .\" | ||||
| .Dd July 19, 1993 | ||||
| .Dt BITSTRING 3 | ||||
| .Os | ||||
| .Sh NAME | ||||
| .Nm bit_alloc , | ||||
| .Nm bit_clear , | ||||
| .Nm bit_decl , | ||||
| .Nm bit_ffs , | ||||
| .Nm bit_nclear , | ||||
| .Nm bit_nset , | ||||
| .Nm bit_set , | ||||
| .Nm bitstr_size , | ||||
| .Nm bit_test | ||||
| .Nd bit-string manipulation macros | ||||
| .Sh SYNOPSIS | ||||
| .In bsd/bitstring.h | ||||
| .Ft bitstr_t * | ||||
| .Fn bit_alloc "int nbits" | ||||
| .Ft void | ||||
| .Fn bit_decl "bitstr_t *name" "int nbits" | ||||
| .Ft void | ||||
| .Fn bit_clear "bitstr_t *name" "int bit" | ||||
| .Ft void | ||||
| .Fn bit_ffc "bitstr_t *name" "int nbits" "int *value" | ||||
| .Ft void | ||||
| .Fn bit_ffs "bitstr_t *name" "int nbits" "int *value" | ||||
| .Ft void | ||||
| .Fn bit_nclear "bitstr_t *name" "int start" "int stop" | ||||
| .Ft void | ||||
| .Fn bit_nset "bitstr_t *name" "int start" "int stop" | ||||
| .Ft void | ||||
| .Fn bit_set "bitstr_t *name" "int bit" | ||||
| .Ft int | ||||
| .Fn bitstr_size "int nbits" | ||||
| .Ft int | ||||
| .Fn bit_test "bitstr_t *name" "int bit" | ||||
| .Sh DESCRIPTION | ||||
| These macros operate on strings of bits. | ||||
| .Pp | ||||
| The macro | ||||
| .Fn bit_alloc | ||||
| returns a pointer of type | ||||
| .Dq Fa "bitstr_t *" | ||||
| to sufficient space to store | ||||
| .Fa nbits | ||||
| bits, or | ||||
| .Dv NULL | ||||
| if no space is available. | ||||
| .Pp | ||||
| The macro | ||||
| .Fn bit_decl | ||||
| allocates sufficient space to store | ||||
| .Fa nbits | ||||
| bits on the stack. | ||||
| .Pp | ||||
| The macro | ||||
| .Fn bitstr_size | ||||
| returns the number of elements of type | ||||
| .Fa bitstr_t | ||||
| necessary to store | ||||
| .Fa nbits | ||||
| bits. | ||||
| This is useful for copying bit strings. | ||||
| .Pp | ||||
| The macros | ||||
| .Fn bit_clear | ||||
| and | ||||
| .Fn bit_set | ||||
| clear or set the zero-based numbered bit | ||||
| .Fa bit , | ||||
| in the bit string | ||||
| .Ar name . | ||||
| .Pp | ||||
| The | ||||
| .Fn bit_nset | ||||
| and | ||||
| .Fn bit_nclear | ||||
| macros | ||||
| set or clear the zero-based numbered bits from | ||||
| .Fa start | ||||
| through | ||||
| .Fa stop | ||||
| in the bit string | ||||
| .Ar name . | ||||
| .Pp | ||||
| The | ||||
| .Fn bit_test | ||||
| macro | ||||
| evaluates to non-zero if the zero-based numbered bit | ||||
| .Fa bit | ||||
| of bit string | ||||
| .Fa name | ||||
| is set, and zero otherwise. | ||||
| .Pp | ||||
| The | ||||
| .Fn bit_ffs | ||||
| macro | ||||
| stores in the location referenced by | ||||
| .Fa value | ||||
| the zero-based number of the first bit set in the array of | ||||
| .Fa nbits | ||||
| bits referenced by | ||||
| .Fa name . | ||||
| If no bits are set, the location referenced by | ||||
| .Fa value | ||||
| is set to \-1. | ||||
| .Pp | ||||
| The macro | ||||
| .Fn bit_ffc | ||||
| stores in the location referenced by | ||||
| .Fa value | ||||
| the zero-based number of the first bit not set in the array of | ||||
| .Fa nbits | ||||
| bits referenced by | ||||
| .Fa name . | ||||
| If all bits are set, the location referenced by | ||||
| .Fa value | ||||
| is set to \-1. | ||||
| .Pp | ||||
| The arguments to these macros are evaluated only once and may safely | ||||
| have side effects. | ||||
| .Sh EXAMPLES | ||||
| .Bd -literal -offset indent | ||||
| #include <limits.h> | ||||
| #include <bsd/bitstring.h> | ||||
|  | ||||
| \&... | ||||
| #define	LPR_BUSY_BIT		0 | ||||
| #define	LPR_FORMAT_BIT		1 | ||||
| #define	LPR_DOWNLOAD_BIT	2 | ||||
| \&... | ||||
| #define	LPR_AVAILABLE_BIT	9 | ||||
| #define	LPR_MAX_BITS		10 | ||||
|  | ||||
| make_lpr_available() | ||||
| { | ||||
| 	bitstr_t bit_decl(bitlist, LPR_MAX_BITS); | ||||
| 	... | ||||
| 	bit_nclear(bitlist, 0, LPR_MAX_BITS - 1); | ||||
| 	... | ||||
| 	if (!bit_test(bitlist, LPR_BUSY_BIT)) { | ||||
| 		bit_clear(bitlist, LPR_FORMAT_BIT); | ||||
| 		bit_clear(bitlist, LPR_DOWNLOAD_BIT); | ||||
| 		bit_set(bitlist, LPR_AVAILABLE_BIT); | ||||
| 	} | ||||
| } | ||||
| .Ed | ||||
| .Sh SEE ALSO | ||||
| .Xr malloc 3 | ||||
| .Sh HISTORY | ||||
| The | ||||
| .Nm bitstring | ||||
| functions first appeared in | ||||
| .Bx 4.4 . | ||||
							
								
								
									
										54
									
								
								man/closefrom.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								man/closefrom.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,54 @@ | ||||
| .\" Copyright (c) 2009 Advanced Computing Technologies LLC | ||||
| .\" Written by: John H. Baldwin <jhb@FreeBSD.org> | ||||
| .\" All rights reserved. | ||||
| .\" | ||||
| .\" 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. | ||||
| .\" | ||||
| .\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``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 OR CONTRIBUTORS 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. | ||||
| .\" | ||||
| .\" $FreeBSD$ | ||||
| .\" | ||||
| .Dd June 12, 2009 | ||||
| .Dt CLOSEFROM 3 | ||||
| .Os | ||||
| .Sh NAME | ||||
| .Nm closefrom | ||||
| .Nd delete open file descriptors | ||||
| .Sh LIBRARY | ||||
| .ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd) | ||||
| .Lb libbsd | ||||
| .Sh SYNOPSIS | ||||
| .In bsd/unistd.h | ||||
| .Ft void | ||||
| .Fn closefrom "int lowfd" | ||||
| .Sh DESCRIPTION | ||||
| The | ||||
| .Fn closefrom | ||||
| system call deletes all open file descriptors greater than or equal to | ||||
| .Fa lowfd | ||||
| from the per-process object reference table. | ||||
| Any errors encountered while closing file descriptors are ignored. | ||||
| .Sh SEE ALSO | ||||
| .Xr close 2 | ||||
| .Sh HISTORY | ||||
| The | ||||
| .Fn closefrom | ||||
| function first appeared in | ||||
| .Fx 8.0 . | ||||
							
								
								
									
										1
									
								
								man/dehumanize_number.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								man/dehumanize_number.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| .so man3/humanize_number.3 | ||||
							
								
								
									
										87
									
								
								man/expand_number.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										87
									
								
								man/expand_number.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,87 @@ | ||||
| .\" Copyright (c) 2007 Eric Anderson <anderson@FreeBSD.org> | ||||
| .\" Copyright (c) 2007 Pawel Jakub Dawidek <pjd@FreeBSD.org> | ||||
| .\" All rights reserved. | ||||
| .\" | ||||
| .\" 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. | ||||
| .\" | ||||
| .\" THIS SOFTWARE IS PROVIDED BY THE AUTHORS AND CONTRIBUTORS ``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 AUTHORS OR CONTRIBUTORS 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. | ||||
| .\" | ||||
| .\" $FreeBSD$ | ||||
| .\" | ||||
| .Dd August 15, 2010 | ||||
| .Dt EXPAND_NUMBER 3 | ||||
| .Os | ||||
| .Sh NAME | ||||
| .Nm expand_number | ||||
| .Nd format a number from human readable form | ||||
| .Sh LIBRARY | ||||
| .ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd) | ||||
| .Lb libbsd | ||||
| .Sh SYNOPSIS | ||||
| .In bsd/libutil.h | ||||
| .Ft int | ||||
| .Fo expand_number | ||||
| .Fa "const char *buf" "uint64_t *num" | ||||
| .Fc | ||||
| .Sh DESCRIPTION | ||||
| The | ||||
| .Fn expand_number | ||||
| function unformats the | ||||
| .Fa buf | ||||
| string and stores a unsigned 64-bit quantity at address pointed out by the | ||||
| .Fa num | ||||
| argument. | ||||
| .Pp | ||||
| The | ||||
| .Fn expand_number | ||||
| function | ||||
| follows the SI power of two convention. | ||||
| .Pp | ||||
| The prefixes are: | ||||
| .Bl -column "Prefix" "Description" "1000000000000000000" -offset indent | ||||
| .It Sy "Prefix" Ta Sy "Description" Ta Sy "Multiplier" | ||||
| .It Li k Ta No kilo Ta 1024 | ||||
| .It Li M Ta No mega Ta 1048576 | ||||
| .It Li G Ta No giga Ta 1073741824 | ||||
| .It Li T Ta No tera Ta 1099511627776 | ||||
| .It Li P Ta No peta Ta 1125899906842624 | ||||
| .It Li E Ta No exa  Ta 1152921504606846976 | ||||
| .El | ||||
| .Sh RETURN VALUES | ||||
| .Rv -std | ||||
| .Sh ERRORS | ||||
| The | ||||
| .Fn expand_number | ||||
| function will fail if: | ||||
| .Bl -tag -width Er | ||||
| .It Bq Er EINVAL | ||||
| The given string contains no digits. | ||||
| .It Bq Er EINVAL | ||||
| An unrecognized prefix was given. | ||||
| .It Bq Er ERANGE | ||||
| Result doesn't fit into 64 bits. | ||||
| .El | ||||
| .Sh SEE ALSO | ||||
| .Xr humanize_number 3 | ||||
| .Sh HISTORY | ||||
| The | ||||
| .Fn expand_number | ||||
| function first appeared in | ||||
| .Fx 6.3 . | ||||
| @@ -35,9 +35,10 @@ | ||||
| .Nm fgetln | ||||
| .Nd get a line from a stream | ||||
| .Sh LIBRARY | ||||
| .Lb libc | ||||
| .ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd) | ||||
| .Lb libbsd | ||||
| .Sh SYNOPSIS | ||||
| .In stdio.h | ||||
| .In bsd/stdio.h | ||||
| .Ft char * | ||||
| .Fn fgetln "FILE *stream" "size_t *len" | ||||
| .Sh DESCRIPTION | ||||
| @@ -54,7 +55,7 @@ character. | ||||
| The length of the line, including the final newline, | ||||
| is stored in the memory location to which | ||||
| .Fa len | ||||
| points. | ||||
| points and is guaranteed to be greater than 0 upon successful completion. | ||||
| (Note, however, that if the line is the last | ||||
| in a file that does not end in a newline, | ||||
| the returned text will not contain a newline.) | ||||
|   | ||||
							
								
								
									
										117
									
								
								man/fgetwln.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										117
									
								
								man/fgetwln.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,117 @@ | ||||
| .\" Copyright (c) 1990, 1991, 1993 | ||||
| .\"	The Regents of the University of California.  All rights reserved. | ||||
| .\" | ||||
| .\" 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. Neither the name of the University nor the names of its contributors | ||||
| .\"    may be used to endorse or promote products derived from this software | ||||
| .\"    without specific prior written permission. | ||||
| .\" | ||||
| .\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``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 REGENTS OR CONTRIBUTORS 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. | ||||
| .\" | ||||
| .\"     @(#)fgetln.3	8.3 (Berkeley) 4/19/94 | ||||
| .\" $FreeBSD$ | ||||
| .\" | ||||
| .Dd July 16, 2004 | ||||
| .Dt FGETWLN 3 | ||||
| .Os | ||||
| .Sh NAME | ||||
| .Nm fgetwln | ||||
| .Nd get a line of wide characters from a stream | ||||
| .Sh LIBRARY | ||||
| .ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd) | ||||
| .Lb libbsd | ||||
| .Sh SYNOPSIS | ||||
| .In stdio.h | ||||
| .In bsd/wchar.h | ||||
| .Ft wchar_t * | ||||
| .Fn fgetwln "FILE * restrict stream" "size_t * restrict len" | ||||
| .Sh DESCRIPTION | ||||
| The | ||||
| .Fn fgetwln | ||||
| function | ||||
| returns a pointer to the next line from the stream referenced by | ||||
| .Fa stream . | ||||
| This line is | ||||
| .Em not | ||||
| a standard wide character string as it does not end with a terminating | ||||
| null wide character. | ||||
| The length of the line, including the final newline, | ||||
| is stored in the memory location to which | ||||
| .Fa len | ||||
| points. | ||||
| (Note, however, that if the line is the last | ||||
| in a file that does not end in a newline, | ||||
| the returned text will not contain a newline.) | ||||
| .Sh RETURN VALUES | ||||
| Upon successful completion a pointer is returned; | ||||
| this pointer becomes invalid after the next | ||||
| .Tn I/O | ||||
| operation on | ||||
| .Fa stream | ||||
| (whether successful or not) | ||||
| or as soon as the stream is closed. | ||||
| Otherwise, | ||||
| .Dv NULL | ||||
| is returned. | ||||
| The | ||||
| .Fn fgetwln | ||||
| function | ||||
| does not distinguish between end-of-file and error; the routines | ||||
| .Xr feof 3 | ||||
| and | ||||
| .Xr ferror 3 | ||||
| must be used | ||||
| to determine which occurred. | ||||
| If an error occurs, the global variable | ||||
| .Va errno | ||||
| is set to indicate the error. | ||||
| The end-of-file condition is remembered, even on a terminal, and all | ||||
| subsequent attempts to read will return | ||||
| .Dv NULL | ||||
| until the condition is | ||||
| cleared with | ||||
| .Xr clearerr 3 . | ||||
| .Pp | ||||
| The text to which the returned pointer points may be modified, | ||||
| provided that no changes are made beyond the returned size. | ||||
| These changes are lost as soon as the pointer becomes invalid. | ||||
| .Sh ERRORS | ||||
| .Bl -tag -width Er | ||||
| .It Bq Er EBADF | ||||
| The argument | ||||
| .Fa stream | ||||
| is not a stream open for reading. | ||||
| .El | ||||
| .Pp | ||||
| The | ||||
| .Fn fgetwln | ||||
| function | ||||
| may also fail and set | ||||
| .Va errno | ||||
| for any of the errors specified for the routines | ||||
| .Xr mbrtowc 3 , | ||||
| .Xr realloc 3 , | ||||
| or | ||||
| .Xr read 2 . | ||||
| .Sh SEE ALSO | ||||
| .Xr ferror 3 , | ||||
| .Xr fgetln 3 , | ||||
| .Xr fgetws 3 , | ||||
| .Xr fopen 3 | ||||
							
								
								
									
										102
									
								
								man/flopen.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										102
									
								
								man/flopen.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,102 @@ | ||||
| .\"- | ||||
| .\" Copyright (c) 2007 Dag-Erling Coïdan Smørgrav | ||||
| .\" All rights reserved. | ||||
| .\" | ||||
| .\" 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. | ||||
| .\" | ||||
| .\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``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 OR CONTRIBUTORS 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. | ||||
| .\" | ||||
| .\" $FreeBSD$ | ||||
| .\" | ||||
| .Dd June 6, 2009 | ||||
| .Dt FLOPEN 3 | ||||
| .Os | ||||
| .Sh NAME | ||||
| .Nm flopen | ||||
| .Nd reliably open and lock a file | ||||
| .Sh LIBRARY | ||||
| .ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd) | ||||
| .Lb libbsd | ||||
| .Sh SYNOPSIS | ||||
| .In sys/fcntl.h | ||||
| .In bsd/libutil.h | ||||
| .Ft int | ||||
| .Fn flopen "const char *path" "int flags" | ||||
| .Ft int | ||||
| .Fn flopen "const char *path" "int flags" "mode_t mode" | ||||
| .Sh DESCRIPTION | ||||
| The | ||||
| .Fn flopen | ||||
| function opens or creates a file and acquires an exclusive lock on it. | ||||
| It is essentially equivalent with calling | ||||
| .Fn open | ||||
| with the same parameters followed by | ||||
| .Fn flock | ||||
| with an | ||||
| .Va operation | ||||
| argument of | ||||
| .Dv LOCK_EX , | ||||
| except that | ||||
| .Fn flopen | ||||
| will attempt to detect and handle races that may occur between opening | ||||
| / creating the file and locking it. | ||||
| Thus, it is well suited for opening lock files, PID files, spool | ||||
| files, mailboxes and other kinds of files which are used for | ||||
| synchronization between processes. | ||||
| .Pp | ||||
| If | ||||
| .Va flags | ||||
| includes | ||||
| .Dv O_NONBLOCK | ||||
| and the file is already locked, | ||||
| .Fn flopen | ||||
| will fail and set | ||||
| .Va errno | ||||
| to | ||||
| .Dv EWOULDBLOCK . | ||||
| .Pp | ||||
| As with | ||||
| .Fn open , | ||||
| the additional | ||||
| .Va mode | ||||
| argument is required if | ||||
| .Va flags | ||||
| includes | ||||
| .Dv O_CREAT . | ||||
| .Sh RETURN VALUES | ||||
| If successful, | ||||
| .Fn flopen | ||||
| returns a valid file descriptor. | ||||
| Otherwise, it returns \-1, and sets | ||||
| .Va errno | ||||
| as described in | ||||
| .Xr flock 2 | ||||
| and | ||||
| .Xr open 2 . | ||||
| .Sh SEE ALSO | ||||
| .Xr errno 2 , | ||||
| .Xr flock 2 , | ||||
| .Xr open 2 | ||||
| .Sh AUTHORS | ||||
| .An -nosplit | ||||
| The | ||||
| .Nm | ||||
| function and this manual page were written by | ||||
| .An Dag-Erling Sm\(/orgrav Aq des@FreeBSD.org . | ||||
| @@ -34,9 +34,10 @@ | ||||
| .Xr printf 3 Ns -style | ||||
| format string | ||||
| .Sh LIBRARY | ||||
| .Lb libc | ||||
| .ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd) | ||||
| .Lb libbsd | ||||
| .Sh SYNOPSIS | ||||
| .In stdio.h | ||||
| .In bsd/stdio.h | ||||
| .Ft const char * | ||||
| .Fn fmtcheck "const char *fmt_suspect" "const char *fmt_default" | ||||
| .Sh DESCRIPTION | ||||
|   | ||||
							
								
								
									
										149
									
								
								man/fparseln.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										149
									
								
								man/fparseln.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,149 @@ | ||||
| .\"	$NetBSD: fparseln.3,v 1.4 2009/10/21 01:07:45 snj Exp $ | ||||
| .\" | ||||
| .\" Copyright (c) 1997 Christos Zoulas.  All rights reserved. | ||||
| .\" | ||||
| .\" 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. | ||||
| .\" | ||||
| .\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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. | ||||
| .\" | ||||
| .Dd November 30, 2002 | ||||
| .Dt FPARSELN 3 | ||||
| .Os | ||||
| .Sh NAME | ||||
| .Nm fparseln | ||||
| .Nd return the next logical line from a stream | ||||
| .Sh LIBRARY | ||||
| .ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd) | ||||
| .Lb libbsd | ||||
| .Sh SYNOPSIS | ||||
| .In bsd/stdio.h | ||||
| .Ft "char *" | ||||
| .Fo "fparseln" | ||||
| .Fa "FILE *stream" "size_t *len" "size_t *lineno" | ||||
| .Fa "const char delim[3]" "int flags" | ||||
| .Fc | ||||
| .Sh DESCRIPTION | ||||
| The | ||||
| .Fn fparseln | ||||
| function | ||||
| returns a pointer to the next logical line from the stream referenced by | ||||
| .Fa stream . | ||||
| This string is | ||||
| .Dv NUL | ||||
| terminated and it is dynamically allocated on each invocation. | ||||
| It is the responsibility of the caller to free the pointer. | ||||
| .Pp | ||||
| By default, if a character is escaped, both it and the preceding escape | ||||
| character will be present in the returned string. | ||||
| Various | ||||
| .Fa flags | ||||
| alter this behaviour. | ||||
| .Pp | ||||
| The meaning of the arguments is as follows: | ||||
| .Bl -tag -width "lineno" | ||||
| .It Fa stream | ||||
| The stream to read from. | ||||
| .It Fa len | ||||
| If not | ||||
| .Dv NULL , | ||||
| the length of the string is stored in the memory location to which it | ||||
| points. | ||||
| .It Fa lineno | ||||
| If not | ||||
| .Dv NULL , | ||||
| the value of the memory location to which is pointed to, is incremented | ||||
| by the number of lines actually read from the file. | ||||
| .It Fa delim | ||||
| Contains the escape, continuation, and comment characters. | ||||
| If a character is | ||||
| .Dv NUL | ||||
| then processing for that character is disabled. | ||||
| If | ||||
| .Dv NULL , | ||||
| all characters default to values specified below. | ||||
| The contents of | ||||
| .Fa delim | ||||
| is as follows: | ||||
| .Bl -tag -width "delim[0]" | ||||
| .It Fa delim[0] | ||||
| The escape character, which defaults to | ||||
| .Cm \e , | ||||
| is used to remove any special meaning from the next character. | ||||
| .It Fa delim[1] | ||||
| The continuation character, which defaults to | ||||
| .Cm \e , | ||||
| is used to indicate that the next line should be concatenated with the | ||||
| current one if this character is the last character on the current line | ||||
| and is not escaped. | ||||
| .It Fa delim[2] | ||||
| The comment character, which defaults to | ||||
| .Cm # , | ||||
| if not escaped indicates the beginning of a comment that extends until the | ||||
| end of the current line. | ||||
| .El | ||||
| .It Fa flags | ||||
| If non-zero, alter the operation of | ||||
| .Fn fparseln . | ||||
| The various flags, which may be | ||||
| .Em or Ns -ed | ||||
| together, are: | ||||
| .Bl -tag -width "FPARSELN_UNESCCOMM" | ||||
| .It Dv FPARSELN_UNESCCOMM | ||||
| Remove escape preceding an escaped comment. | ||||
| .It Dv FPARSELN_UNESCCONT | ||||
| Remove escape preceding an escaped continuation. | ||||
| .It Dv FPARSELN_UNESCESC | ||||
| Remove escape preceding an escaped escape. | ||||
| .It Dv FPARSELN_UNESCREST | ||||
| Remove escape preceding any other character. | ||||
| .It Dv FPARSELN_UNESCALL | ||||
| All of the above. | ||||
| .El | ||||
| .Pp | ||||
| .El | ||||
| .Sh RETURN VALUES | ||||
| Upon successful completion a pointer to the parsed line is returned; | ||||
| otherwise, | ||||
| .Dv NULL | ||||
| is returned. | ||||
| .Pp | ||||
| The | ||||
| .Fn fparseln | ||||
| function uses internally | ||||
| .Xr fgetln 3 , | ||||
| so all error conditions that apply to | ||||
| .Xr fgetln 3 , | ||||
| apply to | ||||
| .Fn fparseln . | ||||
| In addition | ||||
| .Fn fparseln | ||||
| may set | ||||
| .Va errno | ||||
| to | ||||
| .Bq Er ENOMEM | ||||
| and return | ||||
| .Dv NULL | ||||
| if it runs out of memory. | ||||
| .Sh SEE ALSO | ||||
| .Xr fgetln 3 | ||||
| .Sh HISTORY | ||||
| The | ||||
| .Fn fparseln | ||||
| function first appeared in | ||||
| .Nx 1.4 . | ||||
							
								
								
									
										138
									
								
								man/getpeereid.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										138
									
								
								man/getpeereid.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,138 @@ | ||||
| .\" | ||||
| .\" Copyright (c) 2001 Dima Dorfman. | ||||
| .\" All rights reserved. | ||||
| .\" | ||||
| .\" 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. | ||||
| .\" | ||||
| .\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``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 OR CONTRIBUTORS 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. | ||||
| .\" | ||||
| .\" $FreeBSD$ | ||||
| .\" | ||||
| .Dd July 15, 2001 | ||||
| .Dt GETPEEREID 3 | ||||
| .Os | ||||
| .Sh NAME | ||||
| .Nm getpeereid | ||||
| .Nd get the effective credentials of a UNIX-domain peer | ||||
| .Sh LIBRARY | ||||
| .ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd) | ||||
| .Lb libbsd | ||||
| .Sh SYNOPSIS | ||||
| .In sys/types.h | ||||
| .In bsd/unistd.h | ||||
| .Ft int | ||||
| .Fn getpeereid "int s" "uid_t *euid" "gid_t *egid" | ||||
| .Sh DESCRIPTION | ||||
| The | ||||
| .Fn getpeereid | ||||
| function returns the effective user and group IDs of the | ||||
| peer connected to a | ||||
| .Ux Ns -domain | ||||
| socket. | ||||
| The argument | ||||
| .Fa s | ||||
| must be a | ||||
| .Ux Ns -domain | ||||
| socket | ||||
| .Pq Xr unix 4 | ||||
| of type | ||||
| .Dv SOCK_STREAM | ||||
| on which either | ||||
| .Xr connect 2 | ||||
| or | ||||
| .Xr listen 2 | ||||
| have been called. | ||||
| The effective used ID is placed in | ||||
| .Fa euid , | ||||
| and the effective group ID in | ||||
| .Fa egid . | ||||
| .Pp | ||||
| The credentials returned to the | ||||
| .Xr listen 2 | ||||
| caller are those of its peer at the time it called | ||||
| .Xr connect 2 ; | ||||
| the credentials returned to the | ||||
| .Xr connect 2 | ||||
| caller are those of its peer at the time it called | ||||
| .Xr listen 2 . | ||||
| This mechanism is reliable; there is no way for either side to influence | ||||
| the credentials returned to its peer except by calling the appropriate | ||||
| system call (i.e., either | ||||
| .Xr connect 2 | ||||
| or | ||||
| .Xr listen 2 ) | ||||
| under different effective credentials. | ||||
| .Pp | ||||
| One common use of this routine is for a | ||||
| .Ux Ns -domain | ||||
| server | ||||
| to verify the credentials of its client. | ||||
| Likewise, the client can verify the credentials of the server. | ||||
| .Sh IMPLEMENTATION NOTES | ||||
| On | ||||
| .Fx , | ||||
| .Fn getpeereid | ||||
| is implemented in terms of the | ||||
| .Dv LOCAL_PEERCRED | ||||
| .Xr unix 4 | ||||
| socket option. | ||||
| .Sh RETURN VALUES | ||||
| .Rv -std getpeereid | ||||
| .Sh ERRORS | ||||
| The | ||||
| .Fn getpeereid | ||||
| function | ||||
| fails if: | ||||
| .Bl -tag -width Er | ||||
| .It Bq Er EBADF | ||||
| The argument | ||||
| .Fa s | ||||
| is not a valid descriptor. | ||||
| .It Bq Er ENOTSOCK | ||||
| The argument | ||||
| .Fa s | ||||
| is a file, not a socket. | ||||
| .It Bq Er ENOTCONN | ||||
| The argument | ||||
| .Fa s | ||||
| does not refer to a socket on which | ||||
| .Xr connect 2 | ||||
| or | ||||
| .Xr listen 2 | ||||
| have been called. | ||||
| .It Bq Er EINVAL | ||||
| The argument | ||||
| .Fa s | ||||
| does not refer to a socket of type | ||||
| .Dv SOCK_STREAM , | ||||
| or the kernel returned invalid data. | ||||
| .El | ||||
| .Sh SEE ALSO | ||||
| .Xr connect 2 , | ||||
| .Xr getpeername 2 , | ||||
| .Xr getsockname 2 , | ||||
| .Xr getsockopt 2 , | ||||
| .Xr listen 2 , | ||||
| .Xr unix 4 | ||||
| .Sh HISTORY | ||||
| The | ||||
| .Fn getpeereid | ||||
| function appeared in | ||||
| .Fx 4.6 . | ||||
							
								
								
									
										95
									
								
								man/getprogname.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										95
									
								
								man/getprogname.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,95 @@ | ||||
| .\" | ||||
| .\" Copyright (c) 2001 Christopher G. Demetriou | ||||
| .\" All rights reserved. | ||||
| .\" | ||||
| .\" 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. All advertising materials mentioning features or use of this software | ||||
| .\"    must display the following acknowledgement: | ||||
| .\"          This product includes software developed for the | ||||
| .\"          NetBSD Project.  See http://www.netbsd.org/ for | ||||
| .\"          information about NetBSD. | ||||
| .\" 4. 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 BY THE AUTHOR ``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. | ||||
| .\" | ||||
| .\" $FreeBSD$ | ||||
| .\" | ||||
| .Dd May 1, 2001 | ||||
| .Dt GETPROGNAME 3 | ||||
| .Os | ||||
| .Sh NAME | ||||
| .Nm getprogname , | ||||
| .Nm setprogname | ||||
| .Nd get or set the program name | ||||
| .Sh LIBRARY | ||||
| .ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd) | ||||
| .Lb libbsd | ||||
| .Sh SYNOPSIS | ||||
| .In bsd/stdlib.h | ||||
| .Ft const char * | ||||
| .Fn getprogname "void" | ||||
| .Ft void | ||||
| .Fn setprogname "const char *progname" | ||||
| .Sh DESCRIPTION | ||||
| The | ||||
| .Fn getprogname | ||||
| and | ||||
| .Fn setprogname | ||||
| functions manipulate the name of the current program. | ||||
| They are used by error-reporting routines to produce | ||||
| consistent output. | ||||
| .Pp | ||||
| The | ||||
| .Fn getprogname | ||||
| function returns the name of the program. | ||||
| If the name has not been set yet, it will return | ||||
| .Dv NULL . | ||||
| .Pp | ||||
| The | ||||
| .Fn setprogname | ||||
| function sets the name of the program to be the last component of the | ||||
| .Fa progname | ||||
| argument. | ||||
| Since a pointer to the given string is kept as the program name, | ||||
| it should not be modified for the rest of the program's lifetime. | ||||
| .Pp | ||||
| In | ||||
| .Fx , | ||||
| the name of the program is set by the start-up code that is run before | ||||
| .Fn main ; | ||||
| thus, | ||||
| running | ||||
| .Fn setprogname | ||||
| is not necessary. | ||||
| Programs that desire maximum portability should still call it; | ||||
| on another operating system, | ||||
| these functions may be implemented in a portability library. | ||||
| Calling | ||||
| .Fn setprogname | ||||
| allows the aforementioned library to learn the program name without | ||||
| modifications to the start-up code. | ||||
| .Sh SEE ALSO | ||||
| .Xr err 3 , | ||||
| .Xr setproctitle 3 | ||||
| .Sh HISTORY | ||||
| These functions first appeared in | ||||
| .Nx 1.6 , | ||||
| and made their way into | ||||
| .Fx 4.4 . | ||||
							
								
								
									
										208
									
								
								man/heapsort.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										208
									
								
								man/heapsort.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,208 @@ | ||||
| .\" Copyright (c) 1990, 1991, 1993 | ||||
| .\"	The Regents of the University of California.  All rights reserved. | ||||
| .\" | ||||
| .\" This code is derived from software contributed to Berkeley by | ||||
| .\" the American National Standards Committee X3, on Information | ||||
| .\" Processing Systems. | ||||
| .\" | ||||
| .\" 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. | ||||
| .\" 4. Neither the name of the University nor the names of its contributors | ||||
| .\"    may be used to endorse or promote products derived from this software | ||||
| .\"    without specific prior written permission. | ||||
| .\" | ||||
| .\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``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 REGENTS OR CONTRIBUTORS 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. | ||||
| .\" | ||||
| .\"     @(#)qsort.3	8.1 (Berkeley) 6/4/93 | ||||
| .\" $FreeBSD$ | ||||
| .\" | ||||
| .Dd September 30, 2003 | ||||
| .Dt QSORT 3 | ||||
| .Os | ||||
| .Sh NAME | ||||
| .Nm heapsort , mergesort | ||||
| .Nd sort functions | ||||
| .Sh LIBRARY | ||||
| .ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd) | ||||
| .Lb libbsd | ||||
| .Sh SYNOPSIS | ||||
| .In bsd/stdlib.h | ||||
| .Ft int | ||||
| .Fo heapsort | ||||
| .Fa "void *base" | ||||
| .Fa "size_t nmemb" | ||||
| .Fa "size_t size" | ||||
| .Fa "int \*[lp]*compar\*[rp]\*[lp]const void *, const void *\*[rp]" | ||||
| .Fc | ||||
| .Ft int | ||||
| .Fo mergesort | ||||
| .Fa "void *base" | ||||
| .Fa "size_t nmemb" | ||||
| .Fa "size_t size" | ||||
| .Fa "int \*[lp]*compar\*[rp]\*[lp]const void *, const void *\*[rp]" | ||||
| .Fc | ||||
| .Sh DESCRIPTION | ||||
| The | ||||
| .Fn heapsort | ||||
| function is a modified selection sort. | ||||
| The | ||||
| .Fn mergesort | ||||
| function is a modified merge sort with exponential search | ||||
| intended for sorting data with pre-existing order. | ||||
| .Pp | ||||
| The | ||||
| .Fn heapsort | ||||
| function sorts an array of | ||||
| .Fa nmemb | ||||
| objects, the initial member of which is pointed to by | ||||
| .Fa base . | ||||
| The size of each object is specified by | ||||
| .Fa size . | ||||
| The | ||||
| .Fn mergesort | ||||
| function | ||||
| behaves similarly, but | ||||
| .Em requires | ||||
| that | ||||
| .Fa size | ||||
| be greater than | ||||
| .Dq "sizeof(void *) / 2" . | ||||
| .Pp | ||||
| The contents of the array | ||||
| .Fa base | ||||
| are sorted in ascending order according to | ||||
| a comparison function pointed to by | ||||
| .Fa compar , | ||||
| which requires two arguments pointing to the objects being | ||||
| compared. | ||||
| .Pp | ||||
| The comparison function must return an integer less than, equal to, or | ||||
| greater than zero if the first argument is considered to be respectively | ||||
| less than, equal to, or greater than the second. | ||||
| .Pp | ||||
| The algorithm implemented by | ||||
| .Fn heapsort | ||||
| is | ||||
| .Em not | ||||
| stable, that is, if two members compare as equal, their order in | ||||
| the sorted array is undefined. | ||||
| The | ||||
| .Fn mergesort | ||||
| algorithm is stable. | ||||
| .Pp | ||||
| The | ||||
| .Fn heapsort | ||||
| function is an implementation of | ||||
| .An "J.W.J. William" Ns 's | ||||
| .Dq heapsort | ||||
| algorithm, | ||||
| a variant of selection sorting; in particular, see | ||||
| .An "D.E. Knuth" Ns 's | ||||
| .%T "Algorithm H" . | ||||
| .Sy Heapsort | ||||
| takes O N lg N worst-case time. | ||||
| Its | ||||
| .Em only | ||||
| advantage over | ||||
| .Fn qsort | ||||
| is that it uses almost no additional memory; while | ||||
| .Fn qsort | ||||
| does not allocate memory, it is implemented using recursion. | ||||
| .Pp | ||||
| The function | ||||
| .Fn mergesort | ||||
| requires additional memory of size | ||||
| .Fa nmemb * | ||||
| .Fa size | ||||
| bytes; it should be used only when space is not at a premium. | ||||
| The | ||||
| .Fn mergesort | ||||
| function | ||||
| is optimized for data with pre-existing order; its worst case | ||||
| time is O N lg N; its best case is O N. | ||||
| .Pp | ||||
| Normally, | ||||
| .Fn qsort | ||||
| is faster than | ||||
| .Fn mergesort | ||||
| is faster than | ||||
| .Fn heapsort . | ||||
| Memory availability and pre-existing order in the data can make this | ||||
| untrue. | ||||
| .Sh RETURN VALUES | ||||
| .Rv -std heapsort mergesort | ||||
| .Sh ERRORS | ||||
| The | ||||
| .Fn heapsort | ||||
| and | ||||
| .Fn mergesort | ||||
| functions succeed unless: | ||||
| .Bl -tag -width Er | ||||
| .It Bq Er EINVAL | ||||
| The | ||||
| .Fa size | ||||
| argument is zero, or, | ||||
| the | ||||
| .Fa size | ||||
| argument to | ||||
| .Fn mergesort | ||||
| is less than | ||||
| .Dq "sizeof(void *) / 2" . | ||||
| .It Bq Er ENOMEM | ||||
| The | ||||
| .Fn heapsort | ||||
| or | ||||
| .Fn mergesort | ||||
| functions | ||||
| were unable to allocate memory. | ||||
| .El | ||||
| .Sh SEE ALSO | ||||
| .Xr sort 1 , | ||||
| .Xr radixsort 3 | ||||
| .Rs | ||||
| .%A Williams, J.W.J | ||||
| .%D 1964 | ||||
| .%T "Heapsort" | ||||
| .%J "Communications of the ACM" | ||||
| .%V 7:1 | ||||
| .%P pp. 347-348 | ||||
| .Re | ||||
| .Rs | ||||
| .%A Knuth, D.E. | ||||
| .%D 1968 | ||||
| .%B "The Art of Computer Programming" | ||||
| .%V Vol. 3 | ||||
| .%T "Sorting and Searching" | ||||
| .%P pp. 114-123, 145-149 | ||||
| .Re | ||||
| .Rs | ||||
| .%A McIlroy, P.M. | ||||
| .%T "Optimistic Sorting and Information Theoretic Complexity" | ||||
| .%J "Fourth Annual ACM-SIAM Symposium on Discrete Algorithms" | ||||
| .%V January 1992 | ||||
| .Re | ||||
| .Rs | ||||
| .%A Bentley, J.L. | ||||
| .%A McIlroy, M.D. | ||||
| .%T "Engineering a Sort Function" | ||||
| .%J "Software--Practice and Experience" | ||||
| .%V Vol. 23(11) | ||||
| .%P pp. 1249-1265 | ||||
| .%D November\ 1993 | ||||
| .Re | ||||
| @@ -34,8 +34,11 @@ | ||||
| .Nm dehumanize_number , | ||||
| .Nm humanize_number | ||||
| .Nd format a number into a human readable form and viceversa | ||||
| .Sh LIBRARY | ||||
| .ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd) | ||||
| .Lb libbsd | ||||
| .Sh SYNOPSIS | ||||
| .In stdlib.h | ||||
| .In bsd/stdlib.h | ||||
| .Ft int | ||||
| .Fn dehumanize_number "const char *str" "int64_t *result" | ||||
| .Ft int | ||||
| @@ -163,4 +166,6 @@ first appeared in | ||||
| .Pp | ||||
| .Fn dehumanize_number | ||||
| first appeared in | ||||
| .\" FIXME: This should be in groff, but for now it avoids the warning. | ||||
| .ds operating-system-NetBSD-5.0 5.0 | ||||
| .Nx 5.0 . | ||||
|   | ||||
| @@ -10,7 +10,7 @@ | ||||
| .\" 	$OpenBSD: mdX.3,v 1.9 2004/08/24 20:10:33 millert Exp $ | ||||
| .\" | ||||
| .Dd April 29, 2004 | ||||
| .Dt MDX 3 | ||||
| .Dt MDX 3bsd | ||||
| .Os | ||||
| .Sh NAME | ||||
| .Nm MDXInit , | ||||
| @@ -23,9 +23,12 @@ | ||||
| .Nm MDXFileChunk , | ||||
| .Nm MDXData | ||||
| .Nd calculate the RSA Data Security, Inc., ``MDX'' message digest | ||||
| .Sh LIBRARY | ||||
| .ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd) | ||||
| .Lb libbsd | ||||
| .Sh SYNOPSIS | ||||
| .Fd #include <sys/types.h> | ||||
| .Fd #include <mdX.h> | ||||
| .Fd #include <bsd/mdX.h> | ||||
| .Ft void | ||||
| .Fn MDXInit "MDX_CTX *context" | ||||
| .Ft void | ||||
							
								
								
									
										1
									
								
								man/mergesort.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								man/mergesort.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| .so man3/heapsort.3 | ||||
| @@ -35,9 +35,10 @@ | ||||
| .Nm nlist | ||||
| .Nd retrieve symbol table name list from an executable file | ||||
| .Sh LIBRARY | ||||
| .Lb libc | ||||
| .ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd) | ||||
| .Lb libbsd | ||||
| .Sh SYNOPSIS | ||||
| .In nlist.h | ||||
| .In bsd/nlist.h | ||||
| .Ft int | ||||
| .Fn nlist "const char *filename" "struct nlist *nl" | ||||
| .Sh DESCRIPTION | ||||
|   | ||||
							
								
								
									
										254
									
								
								man/pidfile.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										254
									
								
								man/pidfile.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,254 @@ | ||||
| .\" Copyright (c) 2005 Pawel Jakub Dawidek <pjd@FreeBSD.org> | ||||
| .\" All rights reserved. | ||||
| .\" | ||||
| .\" 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. | ||||
| .\" | ||||
| .\" THIS SOFTWARE IS PROVIDED BY THE AUTHORS AND CONTRIBUTORS ``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 AUTHORS OR CONTRIBUTORS 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. | ||||
| .\" | ||||
| .\" $FreeBSD$ | ||||
| .\" | ||||
| .Dd October 20, 2008 | ||||
| .Dt PIDFILE 3 | ||||
| .Os | ||||
| .Sh NAME | ||||
| .Nm pidfile_open , | ||||
| .Nm pidfile_write , | ||||
| .Nm pidfile_close , | ||||
| .Nm pidfile_remove | ||||
| .Nd library for PID files handling | ||||
| .Sh LIBRARY | ||||
| .ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd) | ||||
| .Lb libbsd | ||||
| .Sh SYNOPSIS | ||||
| .In bsd/libutil.h | ||||
| .Ft "struct pidfh *" | ||||
| .Fn pidfile_open "const char *path" "mode_t mode" "pid_t *pidptr" | ||||
| .Ft int | ||||
| .Fn pidfile_write "struct pidfh *pfh" | ||||
| .Ft int | ||||
| .Fn pidfile_close "struct pidfh *pfh" | ||||
| .Ft int | ||||
| .Fn pidfile_remove "struct pidfh *pfh" | ||||
| .Sh DESCRIPTION | ||||
| The | ||||
| .Nm pidfile | ||||
| family of functions allows daemons to handle PID files. | ||||
| It uses | ||||
| .Xr flopen 3 | ||||
| to lock a pidfile and detect already running daemons. | ||||
| .Pp | ||||
| The | ||||
| .Fn pidfile_open | ||||
| function opens (or creates) a file specified by the | ||||
| .Fa path | ||||
| argument and locks it. | ||||
| If a file can not be locked, a PID of an already running daemon is returned in | ||||
| the | ||||
| .Fa pidptr | ||||
| argument (if it is not | ||||
| .Dv NULL ) . | ||||
| The function does not write process' PID into the file here, so it can be | ||||
| used before | ||||
| .Fn fork Ns ing | ||||
| and exit with a proper error message when needed. | ||||
| If the | ||||
| .Fa path | ||||
| argument is | ||||
| .Dv NULL , | ||||
| .Pa /var/run/ Ns Ao Va progname Ac Ns Pa .pid | ||||
| file will be used. | ||||
| .Pp | ||||
| The | ||||
| .Fn pidfile_write | ||||
| function writes process' PID into a previously opened file. | ||||
| .Pp | ||||
| The | ||||
| .Fn pidfile_close | ||||
| function closes a pidfile. | ||||
| It should be used after daemon | ||||
| .Fn fork Ns s | ||||
| to start a child process. | ||||
| .Pp | ||||
| The | ||||
| .Fn pidfile_remove | ||||
| function closes and removes a pidfile. | ||||
| .Sh RETURN VALUES | ||||
| The | ||||
| .Fn pidfile_open | ||||
| function returns a valid pointer to a | ||||
| .Vt pidfh | ||||
| structure on success, or | ||||
| .Dv NULL | ||||
| if an error occurs. | ||||
| If an error occurs, | ||||
| .Va errno | ||||
| will be set. | ||||
| .Pp | ||||
| .Rv -std pidfile_write pidfile_close pidfile_remove | ||||
| .Sh EXAMPLES | ||||
| The following example shows in which order these functions should be used. | ||||
| Note that it is safe to pass | ||||
| .Dv NULL | ||||
| to | ||||
| .Fn pidfile_write , | ||||
| .Fn pidfile_remove | ||||
| and | ||||
| .Fn pidfile_close | ||||
| functions. | ||||
| .Bd -literal | ||||
| struct pidfh *pfh; | ||||
| pid_t otherpid, childpid; | ||||
|  | ||||
| pfh = pidfile_open("/var/run/daemon.pid", 0600, &otherpid); | ||||
| if (pfh == NULL) { | ||||
| 	if (errno == EEXIST) { | ||||
| 		errx(EXIT_FAILURE, "Daemon already running, pid: %jd.", | ||||
| 		    (intmax_t)otherpid); | ||||
| 	} | ||||
| 	/* If we cannot create pidfile from other reasons, only warn. */ | ||||
| 	warn("Cannot open or create pidfile"); | ||||
| } | ||||
|  | ||||
| if (daemon(0, 0) == \-1) { | ||||
| 	warn("Cannot daemonize"); | ||||
| 	pidfile_remove(pfh); | ||||
| 	exit(EXIT_FAILURE); | ||||
| } | ||||
|  | ||||
| pidfile_write(pfh); | ||||
|  | ||||
| for (;;) { | ||||
| 	/* Do work. */ | ||||
| 	childpid = fork(); | ||||
| 	switch (childpid) { | ||||
| 	case \-1: | ||||
| 		syslog(LOG_ERR, "Cannot fork(): %s.", strerror(errno)); | ||||
| 		break; | ||||
| 	case 0: | ||||
| 		pidfile_close(pfh); | ||||
| 		/* Do child work. */ | ||||
| 		break; | ||||
| 	default: | ||||
| 		syslog(LOG_INFO, "Child %jd started.", (intmax_t)childpid); | ||||
| 		break; | ||||
| 	} | ||||
| } | ||||
|  | ||||
| pidfile_remove(pfh); | ||||
| exit(EXIT_SUCCESS); | ||||
| .Ed | ||||
| .Sh ERRORS | ||||
| The | ||||
| .Fn pidfile_open | ||||
| function will fail if: | ||||
| .Bl -tag -width Er | ||||
| .It Bq Er EEXIST | ||||
| Some process already holds the lock on the given pidfile, meaning that a | ||||
| daemon is already running. | ||||
| .It Bq Er ENAMETOOLONG | ||||
| Specified pidfile's name is too long. | ||||
| .It Bq Er EINVAL | ||||
| Some process already holds the lock on the given pidfile, but PID read | ||||
| from there is invalid. | ||||
| .It Bq Er EAGAIN | ||||
| Some process already holds the lock on the given pidfile, but the file | ||||
| is truncated. | ||||
| Most likely, the existing daemon is writing new PID into | ||||
| the file. | ||||
| .El | ||||
| .Pp | ||||
| The | ||||
| .Fn pidfile_open | ||||
| function may also fail and set | ||||
| .Va errno | ||||
| for any errors specified for the | ||||
| .Xr fstat 2 , | ||||
| .Xr open 2 , | ||||
| and | ||||
| .Xr read 2 | ||||
| calls. | ||||
| .Pp | ||||
| The | ||||
| .Fn pidfile_write | ||||
| function will fail if: | ||||
| .Bl -tag -width Er | ||||
| .It Bq Er EINVAL | ||||
| Improper function use. | ||||
| Probably called before | ||||
| .Fn pidfile_open . | ||||
| .El | ||||
| .Pp | ||||
| The | ||||
| .Fn pidfile_write | ||||
| function may also fail and set | ||||
| .Va errno | ||||
| for any errors specified for the | ||||
| .Xr fstat 2 , | ||||
| .Xr ftruncate 2 , | ||||
| and | ||||
| .Xr write 2 | ||||
| calls. | ||||
| .Pp | ||||
| The | ||||
| .Fn pidfile_close | ||||
| function may fail and set | ||||
| .Va errno | ||||
| for any errors specified for the | ||||
| .Xr close 2 | ||||
| and | ||||
| .Xr fstat 2 | ||||
| calls. | ||||
| .Pp | ||||
| The | ||||
| .Fn pidfile_remove | ||||
| function will fail if: | ||||
| .Bl -tag -width Er | ||||
| .It Bq Er EINVAL | ||||
| Improper function use. | ||||
| Probably called not from the process which made | ||||
| .Fn pidfile_write . | ||||
| .El | ||||
| .Pp | ||||
| The | ||||
| .Fn pidfile_remove | ||||
| function may also fail and set | ||||
| .Va errno | ||||
| for any errors specified for the | ||||
| .Xr close 2 , | ||||
| .Xr fstat 2 , | ||||
| .Xr write 2 , | ||||
| and | ||||
| .Xr unlink 2 | ||||
| system calls and the | ||||
| .Xr flopen 3 | ||||
| library function. | ||||
| .Sh SEE ALSO | ||||
| .Xr open 2 , | ||||
| .Xr daemon 3 , | ||||
| .Xr flopen 3 | ||||
| .Sh AUTHORS | ||||
| .An -nosplit | ||||
| The | ||||
| .Nm pidfile | ||||
| functionality is based on ideas from | ||||
| .An John-Mark Gurney Aq jmg@FreeBSD.org . | ||||
| .Pp | ||||
| The code and manual page was written by | ||||
| .An Pawel Jakub Dawidek Aq pjd@FreeBSD.org . | ||||
							
								
								
									
										1040
									
								
								man/queue.3bsd
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1040
									
								
								man/queue.3bsd
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										168
									
								
								man/radixsort.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										168
									
								
								man/radixsort.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,168 @@ | ||||
| .\"	$NetBSD: radixsort.3,v 1.12 2003/04/16 13:34:46 wiz Exp $ | ||||
| .\" | ||||
| .\" Copyright (c) 1990, 1991, 1993 | ||||
| .\"	The Regents of the University of California.  All rights reserved. | ||||
| .\" | ||||
| .\" 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. Neither the name of the University nor the names of its contributors | ||||
| .\"    may be used to endorse or promote products derived from this software | ||||
| .\"    without specific prior written permission. | ||||
| .\" | ||||
| .\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``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 REGENTS OR CONTRIBUTORS 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. | ||||
| .\" | ||||
| .\"     from: @(#)radixsort.3	8.2 (Berkeley) 1/27/94 | ||||
| .\" | ||||
| .Dd January 27, 1994 | ||||
| .Dt RADIXSORT 3 | ||||
| .Os | ||||
| .Sh NAME | ||||
| .Nm radixsort , | ||||
| .Nm sradixsort | ||||
| .Nd radix sort | ||||
| .Sh LIBRARY | ||||
| .ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd) | ||||
| .Lb libbsd | ||||
| .Sh SYNOPSIS | ||||
| .In limits.h | ||||
| .In bsd/stdlib.h | ||||
| .Ft int | ||||
| .Fn radixsort "const unsigned char **base" "int nmemb" "const unsigned char *table" "unsigned endbyte" | ||||
| .Ft int | ||||
| .Fn sradixsort "const unsigned char **base" "int nmemb" "const unsigned char *table" "unsigned endbyte" | ||||
| .Sh DESCRIPTION | ||||
| The | ||||
| .Fn radixsort | ||||
| and | ||||
| .Fn sradixsort | ||||
| functions | ||||
| are implementations of radix sort. | ||||
| .Pp | ||||
| These functions sort an | ||||
| .Fa nmemb | ||||
| element array of pointers to byte strings, with | ||||
| the initial member of which is referenced by | ||||
| .Fa base . | ||||
| The byte strings may contain any values. | ||||
| End of strings is denoted | ||||
| by character which has same weight as user specified value | ||||
| .Fa endbyte . | ||||
| .Fa endbyte | ||||
| has to be between 0 and 255. | ||||
| .Pp | ||||
| Applications may specify a sort order by providing the | ||||
| .Fa table | ||||
| argument. | ||||
| If | ||||
| .Pf non- Dv NULL , | ||||
| .Fa table | ||||
| must reference an array of | ||||
| .Dv UCHAR_MAX | ||||
| + 1 bytes which contains the sort | ||||
| weight of each possible byte value. | ||||
| The end-of-string byte must have a sort weight of 0 or 255 | ||||
| (for sorting in reverse order). | ||||
| More than one byte may have the same sort weight. | ||||
| The | ||||
| .Fa table | ||||
| argument | ||||
| is useful for applications which wish to sort different characters | ||||
| equally, for example, providing a table with the same weights | ||||
| for A-Z as for a-z will result in a case-insensitive sort. | ||||
| If | ||||
| .Fa table | ||||
| is NULL, the contents of the array are sorted in ascending order | ||||
| according to the | ||||
| .Tn ASCII | ||||
| order of the byte strings they reference and | ||||
| .Fa endbyte | ||||
| has a sorting weight of 0. | ||||
| .Pp | ||||
| The | ||||
| .Fn sradixsort | ||||
| function is stable, that is, if two elements compare as equal, their | ||||
| order in the sorted array is unchanged. | ||||
| The | ||||
| .Fn sradixsort | ||||
| function uses additional memory sufficient to hold | ||||
| .Fa nmemb | ||||
| pointers. | ||||
| .Pp | ||||
| The | ||||
| .Fn radixsort | ||||
| function is not stable, but uses no additional memory. | ||||
| .Pp | ||||
| These functions are variants of most-significant-byte radix sorting; in | ||||
| particular, see | ||||
| .An "D.E. Knuth" Ns 's | ||||
| .%T "Algorithm R" | ||||
| and section 5.2.5, exercise 10. | ||||
| They take linear time relative to the number of bytes in the strings. | ||||
| .Sh RETURN VALUES | ||||
| .Rv -std radixsort | ||||
| .Sh ERRORS | ||||
| .Bl -tag -width Er | ||||
| .It Bq Er EINVAL | ||||
| The value of the | ||||
| .Fa endbyte | ||||
| element of | ||||
| .Fa table | ||||
| is not 0 or 255. | ||||
| .El | ||||
| .Pp | ||||
| Additionally, the | ||||
| .Fn sradixsort | ||||
| function | ||||
| may fail and set | ||||
| .Va errno | ||||
| for any of the errors specified for the library routine | ||||
| .Xr malloc 3 . | ||||
| .Sh SEE ALSO | ||||
| .Xr sort 1 , | ||||
| .Xr qsort 3 | ||||
| .Pp | ||||
| .Rs | ||||
| .%A Knuth, D.E. | ||||
| .%D 1968 | ||||
| .%B "The Art of Computer Programming" | ||||
| .%T "Sorting and Searching" | ||||
| .%V Vol. 3 | ||||
| .%P pp. 170-178 | ||||
| .Re | ||||
| .Rs | ||||
| .%A Paige, R. | ||||
| .%D 1987 | ||||
| .%T "Three Partition Refinement Algorithms" | ||||
| .%J "SIAM J. Comput." | ||||
| .%V Vol. 16 | ||||
| .%N No. 6 | ||||
| .Re | ||||
| .Rs | ||||
| .%A McIlroy, P. | ||||
| .%D 1993 | ||||
| .%B "Engineering Radix Sort" | ||||
| .%T "Computing Systems" | ||||
| .%V Vol. 6:1 | ||||
| .%P pp. 5-27 | ||||
| .Re | ||||
| .Sh HISTORY | ||||
| The | ||||
| .Fn radixsort | ||||
| function first appeared in | ||||
| .Bx 4.4 . | ||||
							
								
								
									
										168
									
								
								man/readpassphrase.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										168
									
								
								man/readpassphrase.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,168 @@ | ||||
| .\"	$OpenBSD: readpassphrase.3,v 1.16 2005/07/22 03:16:58 jaredy Exp $ | ||||
| .\" | ||||
| .\" Copyright (c) 2000, 2002 Todd C. Miller <Todd.Miller@courtesan.com> | ||||
| .\" | ||||
| .\" Permission to use, copy, modify, and distribute this software for any | ||||
| .\" purpose with or without fee is hereby granted, provided that the above | ||||
| .\" copyright notice and this permission notice appear in all copies. | ||||
| .\" | ||||
| .\" THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | ||||
| .\" WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | ||||
| .\" MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | ||||
| .\" ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | ||||
| .\" WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | ||||
| .\" ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF | ||||
| .\" OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||||
| .\" | ||||
| .\" Sponsored in part by the Defense Advanced Research Projects | ||||
| .\" Agency (DARPA) and Air Force Research Laboratory, Air Force | ||||
| .\" Materiel Command, USAF, under agreement number F39502-99-1-0512. | ||||
| .\" | ||||
| .Dd $Mdocdate: May 31 2007 $ | ||||
| .Dt READPASSPHRASE 3 | ||||
| .Os | ||||
| .Sh NAME | ||||
| .Nm readpassphrase | ||||
| .Nd get a passphrase from the user | ||||
| .Sh LIBRARY | ||||
| .ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd) | ||||
| .Lb libbsd | ||||
| .Sh SYNOPSIS | ||||
| .Fd #include <bsd/readpassphrase.h> | ||||
| .Ft char * | ||||
| .Fn readpassphrase "const char *prompt" "char *buf" "size_t bufsiz" "int flags" | ||||
| .Sh DESCRIPTION | ||||
| The | ||||
| .Fn readpassphrase | ||||
| function displays a prompt to, and reads in a passphrase from, | ||||
| .Pa /dev/tty . | ||||
| If this file is inaccessible | ||||
| and the | ||||
| .Dv RPP_REQUIRE_TTY | ||||
| flag is not set, | ||||
| .Fn readpassphrase | ||||
| displays the prompt on the standard error output and reads from the standard | ||||
| input. | ||||
| In this case it is generally not possible to turn off echo. | ||||
| .Pp | ||||
| Up to | ||||
| .Fa bufsiz | ||||
| - 1 characters (one is for the NUL) are read into the provided buffer | ||||
| .Fa buf . | ||||
| Any additional | ||||
| characters and the terminating newline (or return) character are discarded. | ||||
| .Pp | ||||
| .Fn readpassphrase | ||||
| takes the following optional | ||||
| .Fa flags : | ||||
| .Bd -literal -offset indent | ||||
| RPP_ECHO_OFF		turn off echo (default behavior) | ||||
| RPP_ECHO_ON		leave echo on | ||||
| RPP_REQUIRE_TTY		fail if there is no tty | ||||
| RPP_FORCELOWER		force input to lower case | ||||
| RPP_FORCEUPPER		force input to upper case | ||||
| RPP_SEVENBIT		strip the high bit from input | ||||
| RPP_STDIN		force read of passphrase from stdin | ||||
| .Ed | ||||
| .Pp | ||||
| The calling process should zero the passphrase as soon as possible to | ||||
| avoid leaving the cleartext passphrase visible in the process's address | ||||
| space. | ||||
| .Sh RETURN VALUES | ||||
| Upon successful completion, | ||||
| .Fn readpassphrase | ||||
| returns a pointer to the NUL-terminated passphrase. | ||||
| If an error is encountered, the terminal state is restored and | ||||
| a null pointer is returned. | ||||
| .Sh FILES | ||||
| .Bl -tag -width /dev/tty -compact | ||||
| .It Pa /dev/tty | ||||
| .El | ||||
| .Sh EXAMPLES | ||||
| The following code fragment will read a passphrase from | ||||
| .Pa /dev/tty | ||||
| into the buffer | ||||
| .Fa passbuf . | ||||
| .Bd -literal -offset indent | ||||
| char passbuf[1024]; | ||||
|  | ||||
| \&... | ||||
|  | ||||
| if (readpassphrase("Response: ", passbuf, sizeof(passbuf), | ||||
|     RPP_REQUIRE_TTY) == NULL) | ||||
| 	errx(1, "unable to read passphrase"); | ||||
|  | ||||
| if (compare(transform(passbuf), epass) != 0) | ||||
| 	errx(1, "bad passphrase"); | ||||
|  | ||||
| \&... | ||||
|  | ||||
| memset(passbuf, 0, sizeof(passbuf)); | ||||
| .Ed | ||||
| .Sh ERRORS | ||||
| .Bl -tag -width Er | ||||
| .It Bq Er EINTR | ||||
| The | ||||
| .Fn readpassphrase | ||||
| function was interrupted by a signal. | ||||
| .It Bq Er EINVAL | ||||
| The | ||||
| .Ar bufsiz | ||||
| argument was zero. | ||||
| .It Bq Er EIO | ||||
| The process is a member of a background process attempting to read | ||||
| from its controlling terminal, the process is ignoring or blocking | ||||
| the | ||||
| .Dv SIGTTIN | ||||
| signal, or the process group is orphaned. | ||||
| .It Bq Er EMFILE | ||||
| The process has already reached its limit for open file descriptors. | ||||
| .It Bq Er ENFILE | ||||
| The system file table is full. | ||||
| .It Bq Er ENOTTY | ||||
| There is no controlling terminal and the | ||||
| .Dv RPP_REQUIRE_TTY | ||||
| flag was specified. | ||||
| .El | ||||
| .Sh SIGNALS | ||||
| .Fn readpassphrase | ||||
| will catch the following signals: | ||||
| .Bd -literal -offset indent | ||||
| SIGALRM		SIGHUP		SIGINT | ||||
| SIGPIPE		SIGQUIT		SIGTERM | ||||
| SIGTSTP		SIGTTIN		SIGTTOU | ||||
| .Ed | ||||
| .Pp | ||||
| When one of the above signals is intercepted, terminal echo will | ||||
| be restored if it had previously been turned off. | ||||
| If a signal handler was installed for the signal when | ||||
| .Fn readpassphrase | ||||
| was called, that handler is then executed. | ||||
| If no handler was previously installed for the signal then the | ||||
| default action is taken as per | ||||
| .Xr sigaction 2 . | ||||
| .Pp | ||||
| The | ||||
| .Dv SIGTSTP , | ||||
| .Dv SIGTTIN , | ||||
| and | ||||
| .Dv SIGTTOU | ||||
| signals (stop signals generated from keyboard or due to terminal I/O | ||||
| from a background process) are treated specially. | ||||
| When the process is resumed after it has been stopped, | ||||
| .Fn readpassphrase | ||||
| will reprint the prompt and the user may then enter a passphrase. | ||||
| .Sh SEE ALSO | ||||
| .Xr sigaction 2 , | ||||
| .Xr getpass 3 | ||||
| .Sh STANDARDS | ||||
| The | ||||
| .Fn readpassphrase | ||||
| function is an | ||||
| .Ox | ||||
| extension and should not be used if portability is desired. | ||||
| .Sh HISTORY | ||||
| The | ||||
| .Fn readpassphrase | ||||
| function first appeared in | ||||
| .Ox 2.9 . | ||||
							
								
								
									
										107
									
								
								man/reallocf.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										107
									
								
								man/reallocf.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,107 @@ | ||||
| .\" Copyright (c) 1980, 1991, 1993 | ||||
| .\"	The Regents of the University of California.  All rights reserved. | ||||
| .\" | ||||
| .\" This code is derived from software contributed to Berkeley by | ||||
| .\" the American National Standards Committee X3, on Information | ||||
| .\" Processing Systems. | ||||
| .\" | ||||
| .\" 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. Neither the name of the University nor the names of its contributors | ||||
| .\"    may be used to endorse or promote products derived from this software | ||||
| .\"    without specific prior written permission. | ||||
| .\" | ||||
| .\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``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 REGENTS OR CONTRIBUTORS 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. | ||||
| .\" | ||||
| .\"     @(#)malloc.3	8.1 (Berkeley) 6/4/93 | ||||
| .\" $FreeBSD: src/lib/libc/stdlib/malloc.3,v 1.80.2.2.2.1 2010/06/14 02:09:06 kensmith Exp $ | ||||
| .\" | ||||
| .Dd September 26, 2009 | ||||
| .Dt MALLOC 3 | ||||
| .Os | ||||
| .Sh NAME | ||||
| .Nm reallocf | ||||
| .Nd general purpose memory allocation functions | ||||
| .Sh LIBRARY | ||||
| .ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd) | ||||
| .Lb libbsd | ||||
| .Sh SYNOPSIS | ||||
| .In bsd/stdlib.h | ||||
| .Ft void * | ||||
| .Fn reallocf "void *ptr" "size_t size" | ||||
| .Sh DESCRIPTION | ||||
| The | ||||
| .Fn reallocf | ||||
| function changes the size of the previously allocated memory referenced by | ||||
| .Fa ptr | ||||
| to | ||||
| .Fa size | ||||
| bytes. | ||||
| The contents of the memory are unchanged up to the lesser of the new and | ||||
| old sizes. | ||||
| If the new size is larger, | ||||
| the contents of the newly allocated portion of the memory are undefined. | ||||
| Upon success, the memory referenced by | ||||
| .Fa ptr | ||||
| is freed and a pointer to the newly allocated memory is returned. | ||||
| Note that | ||||
| .Fn reallocf | ||||
| may move the memory allocation, resulting in a different return value than | ||||
| .Fa ptr . | ||||
| If | ||||
| .Fa ptr | ||||
| is | ||||
| .Dv NULL , | ||||
| the | ||||
| .Fn reallocf | ||||
| function behaves identically to | ||||
| .Fn malloc | ||||
| for the specified size. | ||||
| Upon failure, when the requested memory cannot be allocated, the passed pointer | ||||
| is freed to ease the problems with traditional coding styles for | ||||
| .Fn reallocf | ||||
| causing memory leaks in libraries. | ||||
| .Sh RETURN VALUES | ||||
| The | ||||
| .Fn reallocf | ||||
| function returns a pointer, possibly identical to | ||||
| .Fa ptr , | ||||
| to the allocated memory | ||||
| if successful; otherwise a | ||||
| .Dv NULL | ||||
| pointer is returned, and | ||||
| .Va errno | ||||
| is set to | ||||
| .Er ENOMEM | ||||
| if the error was the result of an allocation failure. | ||||
| The buffer is deallocated in this case. | ||||
| .Sh SEE ALSO | ||||
| .Xr brk 2 , | ||||
| .Xr mmap 2 , | ||||
| .Xr alloca 3 , | ||||
| .Xr calloc 3 , | ||||
| .Xr free 3 , | ||||
| .Xr malloc 3 , | ||||
| .Xr posix_memalign 3 , | ||||
| .Xr realloc 3 , | ||||
| .Sh HISTORY | ||||
| The | ||||
| .Fn reallocf | ||||
| function first appeared in | ||||
| .Fx 3.0 . | ||||
| @@ -1,3 +1,5 @@ | ||||
| .\"	$NetBSD: setmode.3,v 1.18.28.1 2009/01/04 17:02:19 christos Exp $ | ||||
| .\" | ||||
| .\" Copyright (c) 1989, 1991, 1993 | ||||
| .\"	The Regents of the University of California.  All rights reserved. | ||||
| .\" | ||||
| @@ -9,7 +11,7 @@ | ||||
| .\" 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. | ||||
| .\" 4. Neither the name of the University nor the names of its contributors | ||||
| .\" 3. Neither the name of the University nor the names of its contributors | ||||
| .\"    may be used to endorse or promote products derived from this software | ||||
| .\"    without specific prior written permission. | ||||
| .\" | ||||
| @@ -28,7 +30,7 @@ | ||||
| .\"     @(#)setmode.3	8.2 (Berkeley) 4/28/95 | ||||
| .\" $FreeBSD: src/lib/libc/gen/setmode.3,v 1.12 2007/01/09 00:27:55 imp Exp $ | ||||
| .\" | ||||
| .Dd April 28, 1995 | ||||
| .Dd January 4, 2009 | ||||
| .Dt SETMODE 3 | ||||
| .Os | ||||
| .Sh NAME | ||||
| @@ -36,37 +38,44 @@ | ||||
| .Nm setmode | ||||
| .Nd modify mode bits | ||||
| .Sh LIBRARY | ||||
| .Lb libc | ||||
| .ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd) | ||||
| .Lb libbsd | ||||
| .Sh SYNOPSIS | ||||
| .In unistd.h | ||||
| .Ft mode_t | ||||
| .Fn getmode "const void *set" "mode_t mode" | ||||
| .In bsd/unistd.h | ||||
| .Ft void * | ||||
| .Fn setmode "const char *mode_str" | ||||
| .Ft mode_t | ||||
| .Fn getmode "const void *set" "mode_t mode" | ||||
| .Sh DESCRIPTION | ||||
| The | ||||
| .Fn setmode | ||||
| function accepts a string representation of a file mode change, | ||||
| compiles it to binary form, and returns an abstract representation | ||||
| that may be passed to | ||||
| .Fn getmode . | ||||
| The string may be an numeric (octal) or symbolic string of the form | ||||
| accepted by | ||||
| .Xr chmod 1 , | ||||
| and may represent either an exact mode to set or a change to make to | ||||
| the existing mode. | ||||
| .Pp | ||||
| The | ||||
| .Fn getmode | ||||
| function | ||||
| returns a copy of the file permission bits | ||||
| adjusts the file permission bits given by | ||||
| .Fa mode | ||||
| as altered by the values pointed to by | ||||
| .Fa set . | ||||
| While only the mode bits are altered, other parts of the file mode | ||||
| may be examined. | ||||
| according to the compiled change representation | ||||
| .Fa set , | ||||
| and returns the adjusted mode. | ||||
| While only the permission bits are altered, other parts of the file | ||||
| mode, particularly the type, may be examined. | ||||
| .Pp | ||||
| The | ||||
| .Fn setmode | ||||
| function | ||||
| takes an absolute (octal) or symbolic value, as described in | ||||
| .Xr chmod 1 , | ||||
| as an argument | ||||
| and returns a pointer to mode values to be supplied to | ||||
| .Fn getmode . | ||||
| Because some of the symbolic values are relative to the file | ||||
| creation mask, | ||||
| Because some of the possible symbolic values are defined relative to | ||||
| the file creation mask, | ||||
| .Fn setmode | ||||
| may call | ||||
| .Xr umask 2 . | ||||
| .Xr umask 2 , | ||||
| temporarily changing the mask. | ||||
| If this occurs, the file creation mask will be restored before | ||||
| .Fn setmode | ||||
| returns. | ||||
| @@ -74,13 +83,13 @@ If the calling program changes the value of its file creation mask | ||||
| after calling | ||||
| .Fn setmode , | ||||
| .Fn setmode | ||||
| must be called again if | ||||
| must be called again to recompile the mode string if | ||||
| .Fn getmode | ||||
| is to modify future file modes correctly. | ||||
| .Pp | ||||
| If the mode passed to | ||||
| .Fn setmode | ||||
| is invalid or if memory cannot be allocated for the return value, | ||||
| is invalid, | ||||
| .Fn setmode | ||||
| returns | ||||
| .Dv NULL . | ||||
| @@ -93,13 +102,40 @@ and should be returned to the system with | ||||
| .Fn free | ||||
| when the program is done with it, generally after a call to | ||||
| .Fn getmode . | ||||
| .Sh EXAMPLES | ||||
| The effects of the shell command | ||||
| .Ql "chmod a+x myscript.sh" | ||||
| can be duplicated as follows: | ||||
| .Bd -literal -offset indent | ||||
| const char *file = "myscript.sh"; | ||||
| struct stat st; | ||||
| mode_t newmode; | ||||
|  | ||||
| stat(file, \*[Am]st); | ||||
| newmode = getmode(setmode("a+x"), st.st_mode); | ||||
| chmod(file, newmode); | ||||
| .Ed | ||||
| .Sh ERRORS | ||||
| The | ||||
| .Fn setmode | ||||
| function | ||||
| may fail and set errno for any of the errors specified for the library | ||||
| routine | ||||
| .Xr malloc 3 . | ||||
| may fail and set | ||||
| .Va errno | ||||
| for any of the errors specified for the library routines | ||||
| .Xr malloc 3 | ||||
| or | ||||
| .Xr strtol 3 . | ||||
| In addition, | ||||
| .Fn setmode | ||||
| will fail and set | ||||
| .Va errno | ||||
| to: | ||||
| .Bl -tag -width Er | ||||
| .It Bq Er EINVAL | ||||
| The | ||||
| .Fa mode | ||||
| argument does not represent a valid mode. | ||||
| .El | ||||
| .Sh SEE ALSO | ||||
| .Xr chmod 1 , | ||||
| .Xr stat 2 , | ||||
| @@ -112,3 +148,9 @@ and | ||||
| .Fn setmode | ||||
| functions first appeared in | ||||
| .Bx 4.4 . | ||||
| .Sh BUGS | ||||
| The type of | ||||
| .Fa set | ||||
| should really be some opaque struct type used only by these functions | ||||
| rather than | ||||
| .Ft void * . | ||||
|   | ||||
							
								
								
									
										124
									
								
								man/setproctitle.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										124
									
								
								man/setproctitle.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,124 @@ | ||||
| .\" Copyright (c) 1995 Peter Wemm <peter@FreeBSD.org> | ||||
| .\" All rights reserved. | ||||
| .\" | ||||
| .\" Redistribution and use in source and binary forms, with or without | ||||
| .\" modification, is permitted provided that the following conditions | ||||
| .\" are met: | ||||
| .\" 1. Redistributions of source code must retain the above copyright | ||||
| .\"    notice immediately at the beginning of the file, without modification, | ||||
| .\"    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. This work was done expressly for inclusion into FreeBSD.  Other use | ||||
| .\"    is permitted provided this notation is included. | ||||
| .\" 4. Absolutely no warranty of function or purpose is made by the author | ||||
| .\"    Peter Wemm. | ||||
| .\" 5. Modifications may be freely made to this file providing the above | ||||
| .\"    conditions are met. | ||||
| .\" | ||||
| .\" $FreeBSD$ | ||||
| .\" | ||||
| .\" The following requests are required for all man pages. | ||||
| .Dd December 16, 1995 | ||||
| .Dt SETPROCTITLE 3 | ||||
| .Os | ||||
| .Sh NAME | ||||
| .Nm setproctitle | ||||
| .Nd set process title | ||||
| .Sh LIBRARY | ||||
| .ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd) | ||||
| .Lb libbsd | ||||
| .Sh SYNOPSIS | ||||
| .In sys/types.h | ||||
| .In bsd/unistd.h | ||||
| .Ft void | ||||
| .Fn setproctitle "const char *fmt" "..." | ||||
| .Sh DESCRIPTION | ||||
| The | ||||
| .Fn setproctitle | ||||
| library routine sets the process title that appears on the | ||||
| .Xr ps 1 | ||||
| command. | ||||
| .Pp | ||||
| The title is set from the executable's name, followed by the | ||||
| result of a | ||||
| .Xr printf 3 | ||||
| style expansion of the arguments as specified by the | ||||
| .Va fmt | ||||
| argument. | ||||
| If the | ||||
| .Va fmt | ||||
| argument begins with a | ||||
| .Dq - | ||||
| character, the executable's name is skipped. | ||||
| .Pp | ||||
| If | ||||
| .Va fmt | ||||
| is NULL, the process title is restored. | ||||
| .Sh EXAMPLES | ||||
| To set the title on a daemon to indicate its activity: | ||||
| .Bd -literal -offset indent | ||||
| setproctitle("talking to %s", inet_ntoa(addr)); | ||||
| .Ed | ||||
| .Sh SEE ALSO | ||||
| .Xr ps 1 , | ||||
| .Xr w 1 , | ||||
| .Xr kvm 3 , | ||||
| .Xr kvm_getargv 3 , | ||||
| .Xr printf 3 | ||||
| .Sh STANDARDS | ||||
| The | ||||
| .Fn setproctitle | ||||
| function | ||||
| is implicitly non-standard. | ||||
| Other methods of causing the | ||||
| .Xr ps 1 | ||||
| command line to change, including copying over the argv[0] string are | ||||
| also implicitly non-portable. | ||||
| It is preferable to use an operating system | ||||
| supplied | ||||
| .Fn setproctitle | ||||
| if present. | ||||
| .Pp | ||||
| Unfortunately, it is possible that there are other calling conventions | ||||
| to other versions of | ||||
| .Fn setproctitle , | ||||
| although none have been found by the author as yet. | ||||
| This is believed to be | ||||
| the predominant convention. | ||||
| .Pp | ||||
| It is thought that the implementation is compatible with other systems, | ||||
| including | ||||
| .Nx | ||||
| and | ||||
| .Bsx . | ||||
| .Sh HISTORY | ||||
| The | ||||
| .Fn setproctitle | ||||
| function | ||||
| first appeared in | ||||
| .Fx 2.2 . | ||||
| Other operating systems have | ||||
| similar functions. | ||||
| .Sh AUTHORS | ||||
| .An -nosplit | ||||
| .An Peter Wemm Aq peter@FreeBSD.org | ||||
| stole the idea from the | ||||
| .Sy "Sendmail 8.7.3" | ||||
| source code by | ||||
| .An Eric Allman Aq eric@sendmail.org . | ||||
| .Sh BUGS | ||||
| Never pass a string with user-supplied data as a format without using | ||||
| .Ql %s . | ||||
| An attacker can put format specifiers in the string to mangle your stack, | ||||
| leading to a possible security hole. | ||||
| This holds true even if the string was built using a function like | ||||
| .Fn snprintf , | ||||
| as the resulting string may still contain user-supplied conversion specifiers | ||||
| for later interpolation by | ||||
| .Fn setproctitle . | ||||
| .Pp | ||||
| Always use the proper secure idiom: | ||||
| .Pp | ||||
| .Dl setproctitle("%s", string); | ||||
							
								
								
									
										1
									
								
								man/setprogname.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								man/setprogname.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| .so man3/getprogname.3 | ||||
							
								
								
									
										1
									
								
								man/sradixsort.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								man/sradixsort.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| .so man3/radixsort.3 | ||||
| @@ -1,33 +1,20 @@ | ||||
| .\" $OpenBSD: strlcpy.3,v 1.5 1999/06/06 15:17:32 aaron Exp $ | ||||
| .\" $OpenBSD: strlcpy.3,v 1.18 2005/08/06 03:24:19 jaredy Exp $ | ||||
| .\" | ||||
| .\" Copyright (c) 1998 Todd C. Miller <Todd.Miller@courtesan.com> | ||||
| .\" All rights reserved. | ||||
| .\" Copyright (c) 1998, 2000 Todd C. Miller <Todd.Miller@courtesan.com> | ||||
| .\" | ||||
| .\" 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. | ||||
| .\" Permission to use, copy, modify, and distribute this software for any | ||||
| .\" purpose with or without fee is hereby granted, provided that the above | ||||
| .\" copyright notice and this permission notice appear in all copies. | ||||
| .\" | ||||
| .\" 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. | ||||
| .\" THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | ||||
| .\" WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | ||||
| .\" MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | ||||
| .\" ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | ||||
| .\" WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | ||||
| .\" ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF | ||||
| .\" OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||||
| .\" | ||||
| .\" $FreeBSD: /repoman/r/ncvs/src/lib/libc/string/strlcpy.3,v 1.13 2004/07/02 23:52:13 ru Exp $ | ||||
| .\" | ||||
| .Dd June 22, 1998 | ||||
| .Dd $Mdocdate: May 31 2007 $ | ||||
| .Dt STRLCPY 3 | ||||
| .Os | ||||
| .Sh NAME | ||||
| @@ -35,9 +22,10 @@ | ||||
| .Nm strlcat | ||||
| .Nd size-bounded string copying and concatenation | ||||
| .Sh LIBRARY | ||||
| .Lb libc | ||||
| .ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd) | ||||
| .Lb libbsd | ||||
| .Sh SYNOPSIS | ||||
| .In string.h | ||||
| .In bsd/string.h | ||||
| .Ft size_t | ||||
| .Fn strlcpy "char *dst" "const char *src" "size_t size" | ||||
| .Ft size_t | ||||
| @@ -64,7 +52,7 @@ is larger than 0 or, in the case of | ||||
| .Fn strlcat , | ||||
| as long as there is at least one byte free in | ||||
| .Fa dst ) . | ||||
| Note that you should include a byte for the NUL in | ||||
| Note that a byte for the NUL should be included in | ||||
| .Fa size . | ||||
| Also note that | ||||
| .Fn strlcpy | ||||
| @@ -108,8 +96,7 @@ The | ||||
| .Fn strlcpy | ||||
| and | ||||
| .Fn strlcat | ||||
| functions return the total length of the string they tried to | ||||
| create. | ||||
| functions return the total length of the string they tried to create. | ||||
| For | ||||
| .Fn strlcpy | ||||
| that means the length of | ||||
| @@ -121,10 +108,10 @@ that means the initial length of | ||||
| plus | ||||
| the length of | ||||
| .Fa src . | ||||
| While this may seem somewhat confusing it was done to make | ||||
| While this may seem somewhat confusing, it was done to make | ||||
| truncation detection simple. | ||||
| .Pp | ||||
| Note however, that if | ||||
| Note, however, that if | ||||
| .Fn strlcat | ||||
| traverses | ||||
| .Fa size | ||||
| @@ -168,8 +155,8 @@ if (strlcat(pname, file, sizeof(pname)) >= sizeof(pname)) | ||||
| 	goto toolong; | ||||
| .Ed | ||||
| .Pp | ||||
| Since we know how many characters we copied the first time, we can | ||||
| speed things up a bit by using a copy instead of an append: | ||||
| Since it is known how many characters were copied the first time, things | ||||
| can be sped up a bit by using a copy instead of an append: | ||||
| .Bd -literal -offset indent | ||||
| char *dir, *file, pname[MAXPATHLEN]; | ||||
| size_t n; | ||||
|   | ||||
| @@ -35,9 +35,10 @@ | ||||
| .Nm strmode | ||||
| .Nd convert inode status information into a symbolic string | ||||
| .Sh LIBRARY | ||||
| .Lb libc | ||||
| .ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd) | ||||
| .Lb libbsd | ||||
| .Sh SYNOPSIS | ||||
| .In string.h | ||||
| .In bsd/string.h | ||||
| .Ft void | ||||
| .Fn strmode "mode_t mode" "char *bp" | ||||
| .Sh DESCRIPTION | ||||
|   | ||||
							
								
								
									
										110
									
								
								man/strnstr.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										110
									
								
								man/strnstr.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,110 @@ | ||||
| .\" Copyright (c) 2001 Mike Barcroft <mike@FreeBSD.org> | ||||
| .\" Copyright (c) 1990, 1991, 1993 | ||||
| .\"	The Regents of the University of California.  All rights reserved. | ||||
| .\" | ||||
| .\" This code is derived from software contributed to Berkeley by | ||||
| .\" Chris Torek and the American National Standards Committee X3, | ||||
| .\" on Information Processing Systems. | ||||
| .\" | ||||
| .\" 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. Neither the name of the University nor the names of its contributors | ||||
| .\"    may be used to endorse or promote products derived from this software | ||||
| .\"    without specific prior written permission. | ||||
| .\" | ||||
| .\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``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 REGENTS OR CONTRIBUTORS 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. | ||||
| .\" | ||||
| .\"     @(#)strstr.3	8.1 (Berkeley) 6/4/93 | ||||
| .\" $FreeBSD$ | ||||
| .\" | ||||
| .Dd October 11, 2001 | ||||
| .Dt STRSTR 3 | ||||
| .Os | ||||
| .Sh NAME | ||||
| .Nm strnstr | ||||
| .Nd locate a substring in a string | ||||
| .Sh LIBRARY | ||||
| .ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd) | ||||
| .Lb libbsd | ||||
| .Sh SYNOPSIS | ||||
| .In bsd/string.h | ||||
| .Ft char * | ||||
| .Fn strnstr "const char *big" "const char *little" "size_t len" | ||||
| .Sh DESCRIPTION | ||||
| The | ||||
| .Fn strnstr | ||||
| function | ||||
| locates the first occurrence of the null-terminated string | ||||
| .Fa little | ||||
| in the string | ||||
| .Fa big , | ||||
| where not more than | ||||
| .Fa len | ||||
| characters are searched. | ||||
| Characters that appear after a | ||||
| .Ql \e0 | ||||
| character are not searched. | ||||
| Since the | ||||
| .Fn strnstr | ||||
| function is a | ||||
| .Fx | ||||
| specific API, it should only be used when portability is not a concern. | ||||
| .Sh RETURN VALUES | ||||
| If | ||||
| .Fa little | ||||
| is an empty string, | ||||
| .Fa big | ||||
| is returned; | ||||
| if | ||||
| .Fa little | ||||
| occurs nowhere in | ||||
| .Fa big , | ||||
| .Dv NULL | ||||
| is returned; | ||||
| otherwise a pointer to the first character of the first occurrence of | ||||
| .Fa little | ||||
| is returned. | ||||
| .Sh EXAMPLES | ||||
| The following sets the pointer | ||||
| .Va ptr | ||||
| to | ||||
| .Dv NULL , | ||||
| because only the first 4 characters of | ||||
| .Va largestring | ||||
| are searched: | ||||
| .Bd -literal -offset indent | ||||
| const char *largestring = "Foo Bar Baz"; | ||||
| const char *smallstring = "Bar"; | ||||
| char *ptr; | ||||
|  | ||||
| ptr = strnstr(largestring, smallstring, 4); | ||||
| .Ed | ||||
| .Sh SEE ALSO | ||||
| .Xr strstr 3 , | ||||
| .Xr strcasestr 3 , | ||||
| .Xr memchr 3 , | ||||
| .Xr memmem 3 , | ||||
| .Xr strchr 3 , | ||||
| .Xr strcspn 3 , | ||||
| .Xr strpbrk 3 , | ||||
| .Xr strrchr 3 , | ||||
| .Xr strsep 3 , | ||||
| .Xr strspn 3 , | ||||
| .Xr strtok 3 , | ||||
| .Xr wcsstr 3 | ||||
							
								
								
									
										159
									
								
								man/strtonum.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										159
									
								
								man/strtonum.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,159 @@ | ||||
| .\" Copyright (c) 2004 Ted Unangst | ||||
| .\" | ||||
| .\" Permission to use, copy, modify, and distribute this software for any | ||||
| .\" purpose with or without fee is hereby granted, provided that the above | ||||
| .\" copyright notice and this permission notice appear in all copies. | ||||
| .\" | ||||
| .\" THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | ||||
| .\" WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | ||||
| .\" MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | ||||
| .\" ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | ||||
| .\" WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | ||||
| .\" ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF | ||||
| .\" OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||||
| .\" | ||||
| .\" $OpenBSD: strtonum.3,v 1.12 2005/10/26 11:37:58 jmc Exp $ | ||||
| .\" $FreeBSD$ | ||||
| .\" | ||||
| .Dd April 29, 2004 | ||||
| .Dt STRTONUM 3 | ||||
| .Os | ||||
| .Sh NAME | ||||
| .Nm strtonum | ||||
| .Nd reliably convert string value to an integer | ||||
| .Sh LIBRARY | ||||
| .ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd) | ||||
| .Lb libbsd | ||||
| .Sh SYNOPSIS | ||||
| .In limits.h | ||||
| .In bsd/stdlib.h | ||||
| .Ft long long | ||||
| .Fo strtonum | ||||
| .Fa "const char *nptr" | ||||
| .Fa "long long minval" | ||||
| .Fa "long long maxval" | ||||
| .Fa "const char **errstr" | ||||
| .Fc | ||||
| .Sh DESCRIPTION | ||||
| The | ||||
| .Fn strtonum | ||||
| function converts the string in | ||||
| .Fa nptr | ||||
| to a | ||||
| .Vt "long long" | ||||
| value. | ||||
| The | ||||
| .Fn strtonum | ||||
| function was designed to facilitate safe, robust programming | ||||
| and overcome the shortcomings of the | ||||
| .Xr atoi 3 | ||||
| and | ||||
| .Xr strtol 3 | ||||
| family of interfaces. | ||||
| .Pp | ||||
| The string may begin with an arbitrary amount of whitespace | ||||
| (as determined by | ||||
| .Xr isspace 3 ) | ||||
| followed by a single optional | ||||
| .Ql + | ||||
| or | ||||
| .Ql - | ||||
| sign. | ||||
| .Pp | ||||
| The remainder of the string is converted to a | ||||
| .Vt "long long" | ||||
| value according to base 10. | ||||
| .Pp | ||||
| The value obtained is then checked against the provided | ||||
| .Fa minval | ||||
| and | ||||
| .Fa maxval | ||||
| bounds. | ||||
| If | ||||
| .Fa errstr | ||||
| is non-null, | ||||
| .Fn strtonum | ||||
| stores an error string in | ||||
| .Fa *errstr | ||||
| indicating the failure. | ||||
| .Sh RETURN VALUES | ||||
| The | ||||
| .Fn strtonum | ||||
| function returns the result of the conversion, | ||||
| unless the value would exceed the provided bounds or is invalid. | ||||
| On error, 0 is returned, | ||||
| .Va errno | ||||
| is set, and | ||||
| .Fa errstr | ||||
| will point to an error message. | ||||
| On success, | ||||
| .Fa *errstr | ||||
| will be set to | ||||
| .Dv NULL ; | ||||
| this fact can be used to differentiate | ||||
| a successful return of 0 from an error. | ||||
| .Sh EXAMPLES | ||||
| Using | ||||
| .Fn strtonum | ||||
| correctly is meant to be simpler than the alternative functions. | ||||
| .Bd -literal -offset indent | ||||
| int iterations; | ||||
| const char *errstr; | ||||
|  | ||||
| iterations = strtonum(optarg, 1, 64, &errstr); | ||||
| if (errstr) | ||||
| 	errx(1, "number of iterations is %s: %s", errstr, optarg); | ||||
| .Ed | ||||
| .Pp | ||||
| The above example will guarantee that the value of iterations is between | ||||
| 1 and 64 (inclusive). | ||||
| .Sh ERRORS | ||||
| .Bl -tag -width Er | ||||
| .It Bq Er ERANGE | ||||
| The given string was out of range. | ||||
| .It Bq Er EINVAL | ||||
| The given string did not consist solely of digit characters. | ||||
| .It Bq Er EINVAL | ||||
| The supplied | ||||
| .Fa minval | ||||
| was larger than | ||||
| .Fa maxval . | ||||
| .El | ||||
| .Pp | ||||
| If an error occurs, | ||||
| .Fa errstr | ||||
| will be set to one of the following strings: | ||||
| .Pp | ||||
| .Bl -tag -width ".Li too large" -compact | ||||
| .It Li "too large" | ||||
| The result was larger than the provided maximum value. | ||||
| .It Li "too small" | ||||
| The result was smaller than the provided minimum value. | ||||
| .It Li invalid | ||||
| The string did not consist solely of digit characters. | ||||
| .El | ||||
| .Sh SEE ALSO | ||||
| .Xr atof 3 , | ||||
| .Xr atoi 3 , | ||||
| .Xr atol 3 , | ||||
| .Xr atoll 3 , | ||||
| .Xr sscanf 3 , | ||||
| .Xr strtod 3 , | ||||
| .Xr strtol 3 , | ||||
| .Xr strtoul 3 | ||||
| .Sh STANDARDS | ||||
| The | ||||
| .Fn strtonum | ||||
| function is a | ||||
| .Bx | ||||
| extension. | ||||
| The existing alternatives, such as | ||||
| .Xr atoi 3 | ||||
| and | ||||
| .Xr strtol 3 , | ||||
| are either impossible or difficult to use safely. | ||||
| .Sh HISTORY | ||||
| The | ||||
| .Fn strtonum | ||||
| function first appeared in | ||||
| .Ox 3.6 . | ||||
							
								
								
									
										504
									
								
								man/tree.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										504
									
								
								man/tree.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,504 @@ | ||||
| .\"	$OpenBSD: tree.3,v 1.7 2002/06/12 01:09:20 provos Exp $ | ||||
| .\" | ||||
| .\" Copyright 2002 Niels Provos <provos@citi.umich.edu> | ||||
| .\" All rights reserved. | ||||
| .\" | ||||
| .\" 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. All advertising materials mentioning features or use of this software | ||||
| .\"    must display the following acknowledgement: | ||||
| .\"      This product includes software developed by Niels Provos. | ||||
| .\" 4. 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 BY THE AUTHOR ``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. | ||||
| .\" | ||||
| .\" $FreeBSD$ | ||||
| .\" | ||||
| .Dd December 27, 2007 | ||||
| .Dt TREE 3 | ||||
| .Os | ||||
| .Sh NAME | ||||
| .Nm SPLAY_PROTOTYPE , | ||||
| .Nm SPLAY_GENERATE , | ||||
| .Nm SPLAY_ENTRY , | ||||
| .Nm SPLAY_HEAD , | ||||
| .Nm SPLAY_INITIALIZER , | ||||
| .Nm SPLAY_ROOT , | ||||
| .Nm SPLAY_EMPTY , | ||||
| .Nm SPLAY_NEXT , | ||||
| .Nm SPLAY_MIN , | ||||
| .Nm SPLAY_MAX , | ||||
| .Nm SPLAY_FIND , | ||||
| .Nm SPLAY_LEFT , | ||||
| .Nm SPLAY_RIGHT , | ||||
| .Nm SPLAY_FOREACH , | ||||
| .Nm SPLAY_INIT , | ||||
| .Nm SPLAY_INSERT , | ||||
| .Nm SPLAY_REMOVE , | ||||
| .Nm RB_PROTOTYPE , | ||||
| .Nm RB_PROTOTYPE_STATIC , | ||||
| .Nm RB_GENERATE , | ||||
| .Nm RB_GENERATE_STATIC , | ||||
| .Nm RB_ENTRY , | ||||
| .Nm RB_HEAD , | ||||
| .Nm RB_INITIALIZER , | ||||
| .Nm RB_ROOT , | ||||
| .Nm RB_EMPTY , | ||||
| .Nm RB_NEXT , | ||||
| .Nm RB_PREV , | ||||
| .Nm RB_MIN , | ||||
| .Nm RB_MAX , | ||||
| .Nm RB_FIND , | ||||
| .Nm RB_NFIND , | ||||
| .Nm RB_LEFT , | ||||
| .Nm RB_RIGHT , | ||||
| .Nm RB_PARENT , | ||||
| .Nm RB_FOREACH , | ||||
| .Nm RB_FOREACH_REVERSE , | ||||
| .Nm RB_INIT , | ||||
| .Nm RB_INSERT , | ||||
| .Nm RB_REMOVE | ||||
| .Nd implementations of splay and red-black trees | ||||
| .Sh SYNOPSIS | ||||
| .In bsd/sys/tree.h | ||||
| .Fn SPLAY_PROTOTYPE NAME TYPE FIELD CMP | ||||
| .Fn SPLAY_GENERATE NAME TYPE FIELD CMP | ||||
| .Fn SPLAY_ENTRY TYPE | ||||
| .Fn SPLAY_HEAD HEADNAME TYPE | ||||
| .Ft "struct TYPE *" | ||||
| .Fn SPLAY_INITIALIZER "SPLAY_HEAD *head" | ||||
| .Fn SPLAY_ROOT "SPLAY_HEAD *head" | ||||
| .Ft bool | ||||
| .Fn SPLAY_EMPTY "SPLAY_HEAD *head" | ||||
| .Ft "struct TYPE *" | ||||
| .Fn SPLAY_NEXT NAME "SPLAY_HEAD *head" "struct TYPE *elm" | ||||
| .Ft "struct TYPE *" | ||||
| .Fn SPLAY_MIN NAME "SPLAY_HEAD *head" | ||||
| .Ft "struct TYPE *" | ||||
| .Fn SPLAY_MAX NAME "SPLAY_HEAD *head" | ||||
| .Ft "struct TYPE *" | ||||
| .Fn SPLAY_FIND NAME "SPLAY_HEAD *head" "struct TYPE *elm" | ||||
| .Ft "struct TYPE *" | ||||
| .Fn SPLAY_LEFT "struct TYPE *elm" "SPLAY_ENTRY NAME" | ||||
| .Ft "struct TYPE *" | ||||
| .Fn SPLAY_RIGHT "struct TYPE *elm" "SPLAY_ENTRY NAME" | ||||
| .Fn SPLAY_FOREACH VARNAME NAME "SPLAY_HEAD *head" | ||||
| .Ft void | ||||
| .Fn SPLAY_INIT "SPLAY_HEAD *head" | ||||
| .Ft "struct TYPE *" | ||||
| .Fn SPLAY_INSERT NAME "SPLAY_HEAD *head" "struct TYPE *elm" | ||||
| .Ft "struct TYPE *" | ||||
| .Fn SPLAY_REMOVE NAME "SPLAY_HEAD *head" "struct TYPE *elm" | ||||
| .Fn RB_PROTOTYPE NAME TYPE FIELD CMP | ||||
| .Fn RB_PROTOTYPE_STATIC NAME TYPE FIELD CMP | ||||
| .Fn RB_GENERATE NAME TYPE FIELD CMP | ||||
| .Fn RB_GENERATE_STATIC NAME TYPE FIELD CMP | ||||
| .Fn RB_ENTRY TYPE | ||||
| .Fn RB_HEAD HEADNAME TYPE | ||||
| .Fn RB_INITIALIZER "RB_HEAD *head" | ||||
| .Ft "struct TYPE *" | ||||
| .Fn RB_ROOT "RB_HEAD *head" | ||||
| .Ft "bool" | ||||
| .Fn RB_EMPTY "RB_HEAD *head" | ||||
| .Ft "struct TYPE *" | ||||
| .Fn RB_NEXT NAME "RB_HEAD *head" "struct TYPE *elm" | ||||
| .Ft "struct TYPE *" | ||||
| .Fn RB_PREV NAME "RB_HEAD *head" "struct TYPE *elm" | ||||
| .Ft "struct TYPE *" | ||||
| .Fn RB_MIN NAME "RB_HEAD *head" | ||||
| .Ft "struct TYPE *" | ||||
| .Fn RB_MAX NAME "RB_HEAD *head" | ||||
| .Ft "struct TYPE *" | ||||
| .Fn RB_FIND NAME "RB_HEAD *head" "struct TYPE *elm" | ||||
| .Ft "struct TYPE *" | ||||
| .Fn RB_NFIND NAME "RB_HEAD *head" "struct TYPE *elm" | ||||
| .Ft "struct TYPE *" | ||||
| .Fn RB_LEFT "struct TYPE *elm" "RB_ENTRY NAME" | ||||
| .Ft "struct TYPE *" | ||||
| .Fn RB_RIGHT "struct TYPE *elm" "RB_ENTRY NAME" | ||||
| .Ft "struct TYPE *" | ||||
| .Fn RB_PARENT "struct TYPE *elm" "RB_ENTRY NAME" | ||||
| .Fn RB_FOREACH VARNAME NAME "RB_HEAD *head" | ||||
| .Fn RB_FOREACH_REVERSE VARNAME NAME "RB_HEAD *head" | ||||
| .Ft void | ||||
| .Fn RB_INIT "RB_HEAD *head" | ||||
| .Ft "struct TYPE *" | ||||
| .Fn RB_INSERT NAME "RB_HEAD *head" "struct TYPE *elm" | ||||
| .Ft "struct TYPE *" | ||||
| .Fn RB_REMOVE NAME "RB_HEAD *head" "struct TYPE *elm" | ||||
| .Sh DESCRIPTION | ||||
| These macros define data structures for different types of trees: | ||||
| splay trees and red-black trees. | ||||
| .Pp | ||||
| In the macro definitions, | ||||
| .Fa TYPE | ||||
| is the name tag of a user defined structure that must contain a field of type | ||||
| .Vt SPLAY_ENTRY , | ||||
| or | ||||
| .Vt RB_ENTRY , | ||||
| named | ||||
| .Fa ENTRYNAME . | ||||
| The argument | ||||
| .Fa HEADNAME | ||||
| is the name tag of a user defined structure that must be declared | ||||
| using the macros | ||||
| .Fn SPLAY_HEAD , | ||||
| or | ||||
| .Fn RB_HEAD . | ||||
| The argument | ||||
| .Fa NAME | ||||
| has to be a unique name prefix for every tree that is defined. | ||||
| .Pp | ||||
| The function prototypes are declared with | ||||
| .Fn SPLAY_PROTOTYPE , | ||||
| .Fn RB_PROTOTYPE , | ||||
| or | ||||
| .Fn RB_PROTOTYPE_STATIC . | ||||
| The function bodies are generated with | ||||
| .Fn SPLAY_GENERATE , | ||||
| .Fn RB_GENERATE , | ||||
| or | ||||
| .Fn RB_GENERATE_STATIC . | ||||
| See the examples below for further explanation of how these macros are used. | ||||
| .Sh SPLAY TREES | ||||
| A splay tree is a self-organizing data structure. | ||||
| Every operation on the tree causes a splay to happen. | ||||
| The splay moves the requested | ||||
| node to the root of the tree and partly rebalances it. | ||||
| .Pp | ||||
| This has the benefit that request locality causes faster lookups as | ||||
| the requested nodes move to the top of the tree. | ||||
| On the other hand, every lookup causes memory writes. | ||||
| .Pp | ||||
| The Balance Theorem bounds the total access time for | ||||
| .Ar m | ||||
| operations and | ||||
| .Ar n | ||||
| inserts on an initially empty tree as | ||||
| .Fn O "\*[lp]m + n\*[rp]lg n" . | ||||
| The | ||||
| amortized cost for a sequence of | ||||
| .Ar m | ||||
| accesses to a splay tree is | ||||
| .Fn O "lg n" . | ||||
| .Pp | ||||
| A splay tree is headed by a structure defined by the | ||||
| .Fn SPLAY_HEAD | ||||
| macro. | ||||
| A | ||||
| structure is declared as follows: | ||||
| .Bd -ragged -offset indent | ||||
| .Fn SPLAY_HEAD HEADNAME TYPE | ||||
| .Va head ; | ||||
| .Ed | ||||
| .Pp | ||||
| where | ||||
| .Fa HEADNAME | ||||
| is the name of the structure to be defined, and struct | ||||
| .Fa TYPE | ||||
| is the type of the elements to be inserted into the tree. | ||||
| .Pp | ||||
| The | ||||
| .Fn SPLAY_ENTRY | ||||
| macro declares a structure that allows elements to be connected in the tree. | ||||
| .Pp | ||||
| In order to use the functions that manipulate the tree structure, | ||||
| their prototypes need to be declared with the | ||||
| .Fn SPLAY_PROTOTYPE | ||||
| macro, | ||||
| where | ||||
| .Fa NAME | ||||
| is a unique identifier for this particular tree. | ||||
| The | ||||
| .Fa TYPE | ||||
| argument is the type of the structure that is being managed | ||||
| by the tree. | ||||
| The | ||||
| .Fa FIELD | ||||
| argument is the name of the element defined by | ||||
| .Fn SPLAY_ENTRY . | ||||
| .Pp | ||||
| The function bodies are generated with the | ||||
| .Fn SPLAY_GENERATE | ||||
| macro. | ||||
| It takes the same arguments as the | ||||
| .Fn SPLAY_PROTOTYPE | ||||
| macro, but should be used only once. | ||||
| .Pp | ||||
| Finally, | ||||
| the | ||||
| .Fa CMP | ||||
| argument is the name of a function used to compare tree nodes | ||||
| with each other. | ||||
| The function takes two arguments of type | ||||
| .Vt "struct TYPE *" . | ||||
| If the first argument is smaller than the second, the function returns a | ||||
| value smaller than zero. | ||||
| If they are equal, the function returns zero. | ||||
| Otherwise, it should return a value greater than zero. | ||||
| The compare | ||||
| function defines the order of the tree elements. | ||||
| .Pp | ||||
| The | ||||
| .Fn SPLAY_INIT | ||||
| macro initializes the tree referenced by | ||||
| .Fa head . | ||||
| .Pp | ||||
| The splay tree can also be initialized statically by using the | ||||
| .Fn SPLAY_INITIALIZER | ||||
| macro like this: | ||||
| .Bd -ragged -offset indent | ||||
| .Fn SPLAY_HEAD HEADNAME TYPE | ||||
| .Va head | ||||
| = | ||||
| .Fn SPLAY_INITIALIZER &head ; | ||||
| .Ed | ||||
| .Pp | ||||
| The | ||||
| .Fn SPLAY_INSERT | ||||
| macro inserts the new element | ||||
| .Fa elm | ||||
| into the tree. | ||||
| .Pp | ||||
| The | ||||
| .Fn SPLAY_REMOVE | ||||
| macro removes the element | ||||
| .Fa elm | ||||
| from the tree pointed by | ||||
| .Fa head . | ||||
| .Pp | ||||
| The | ||||
| .Fn SPLAY_FIND | ||||
| macro can be used to find a particular element in the tree. | ||||
| .Bd -literal -offset indent | ||||
| struct TYPE find, *res; | ||||
| find.key = 30; | ||||
| res = SPLAY_FIND(NAME, head, &find); | ||||
| .Ed | ||||
| .Pp | ||||
| The | ||||
| .Fn SPLAY_ROOT , | ||||
| .Fn SPLAY_MIN , | ||||
| .Fn SPLAY_MAX , | ||||
| and | ||||
| .Fn SPLAY_NEXT | ||||
| macros can be used to traverse the tree: | ||||
| .Bd -literal -offset indent | ||||
| for (np = SPLAY_MIN(NAME, &head); np != NULL; np = SPLAY_NEXT(NAME, &head, np)) | ||||
| .Ed | ||||
| .Pp | ||||
| Or, for simplicity, one can use the | ||||
| .Fn SPLAY_FOREACH | ||||
| macro: | ||||
| .Bd -ragged -offset indent | ||||
| .Fn SPLAY_FOREACH np NAME head | ||||
| .Ed | ||||
| .Pp | ||||
| The | ||||
| .Fn SPLAY_EMPTY | ||||
| macro should be used to check whether a splay tree is empty. | ||||
| .Sh RED-BLACK TREES | ||||
| A red-black tree is a binary search tree with the node color as an | ||||
| extra attribute. | ||||
| It fulfills a set of conditions: | ||||
| .Bl -enum -offset indent | ||||
| .It | ||||
| Every search path from the root to a leaf consists of the same number of | ||||
| black nodes. | ||||
| .It | ||||
| Each red node (except for the root) has a black parent. | ||||
| .It | ||||
| Each leaf node is black. | ||||
| .El | ||||
| .Pp | ||||
| Every operation on a red-black tree is bounded as | ||||
| .Fn O "lg n" . | ||||
| The maximum height of a red-black tree is | ||||
| .Fn 2lg "n + 1" . | ||||
| .Pp | ||||
| A red-black tree is headed by a structure defined by the | ||||
| .Fn RB_HEAD | ||||
| macro. | ||||
| A | ||||
| structure is declared as follows: | ||||
| .Bd -ragged -offset indent | ||||
| .Fn RB_HEAD HEADNAME TYPE | ||||
| .Va head ; | ||||
| .Ed | ||||
| .Pp | ||||
| where | ||||
| .Fa HEADNAME | ||||
| is the name of the structure to be defined, and struct | ||||
| .Fa TYPE | ||||
| is the type of the elements to be inserted into the tree. | ||||
| .Pp | ||||
| The | ||||
| .Fn RB_ENTRY | ||||
| macro declares a structure that allows elements to be connected in the tree. | ||||
| .Pp | ||||
| In order to use the functions that manipulate the tree structure, | ||||
| their prototypes need to be declared with the | ||||
| .Fn RB_PROTOTYPE | ||||
| or | ||||
| .Fn RB_PROTOTYPE_STATIC | ||||
| macro, | ||||
| where | ||||
| .Fa NAME | ||||
| is a unique identifier for this particular tree. | ||||
| The | ||||
| .Fa TYPE | ||||
| argument is the type of the structure that is being managed | ||||
| by the tree. | ||||
| The | ||||
| .Fa FIELD | ||||
| argument is the name of the element defined by | ||||
| .Fn RB_ENTRY . | ||||
| .Pp | ||||
| The function bodies are generated with the | ||||
| .Fn RB_GENERATE | ||||
| or | ||||
| .Fn RB_GENERATE_STATIC | ||||
| macro. | ||||
| These macros take the same arguments as the | ||||
| .Fn RB_PROTOTYPE | ||||
| and | ||||
| .Fn RB_PROTOTYPE_STATIC | ||||
| macros, but should be used only once. | ||||
| .Pp | ||||
| Finally, | ||||
| the | ||||
| .Fa CMP | ||||
| argument is the name of a function used to compare tree nodes | ||||
| with each other. | ||||
| The function takes two arguments of type | ||||
| .Vt "struct TYPE *" . | ||||
| If the first argument is smaller than the second, the function returns a | ||||
| value smaller than zero. | ||||
| If they are equal, the function returns zero. | ||||
| Otherwise, it should return a value greater than zero. | ||||
| The compare | ||||
| function defines the order of the tree elements. | ||||
| .Pp | ||||
| The | ||||
| .Fn RB_INIT | ||||
| macro initializes the tree referenced by | ||||
| .Fa head . | ||||
| .Pp | ||||
| The red-black tree can also be initialized statically by using the | ||||
| .Fn RB_INITIALIZER | ||||
| macro like this: | ||||
| .Bd -ragged -offset indent | ||||
| .Fn RB_HEAD HEADNAME TYPE | ||||
| .Va head | ||||
| = | ||||
| .Fn RB_INITIALIZER &head ; | ||||
| .Ed | ||||
| .Pp | ||||
| The | ||||
| .Fn RB_INSERT | ||||
| macro inserts the new element | ||||
| .Fa elm | ||||
| into the tree. | ||||
| .Pp | ||||
| The | ||||
| .Fn RB_REMOVE | ||||
| macro removes the element | ||||
| .Fa elm | ||||
| from the tree pointed by | ||||
| .Fa head . | ||||
| .Pp | ||||
| The | ||||
| .Fn RB_FIND | ||||
| and | ||||
| .Fn RB_NFIND | ||||
| macros can be used to find a particular element in the tree. | ||||
| .Bd -literal -offset indent | ||||
| struct TYPE find, *res; | ||||
| find.key = 30; | ||||
| res = RB_FIND(NAME, head, &find); | ||||
| .Ed | ||||
| .Pp | ||||
| The | ||||
| .Fn RB_ROOT , | ||||
| .Fn RB_MIN , | ||||
| .Fn RB_MAX , | ||||
| .Fn RB_NEXT , | ||||
| and | ||||
| .Fn RB_PREV | ||||
| macros can be used to traverse the tree: | ||||
| .Pp | ||||
| .Dl "for (np = RB_MIN(NAME, &head); np != NULL; np = RB_NEXT(NAME, &head, np))" | ||||
| .Pp | ||||
| Or, for simplicity, one can use the | ||||
| .Fn RB_FOREACH | ||||
| or | ||||
| .Fn RB_FOREACH_REVERSE | ||||
| macro: | ||||
| .Bd -ragged -offset indent | ||||
| .Fn RB_FOREACH np NAME head | ||||
| .Ed | ||||
| .Pp | ||||
| The | ||||
| .Fn RB_EMPTY | ||||
| macro should be used to check whether a red-black tree is empty. | ||||
| .Sh NOTES | ||||
| Trying to free a tree in the following way is a common error: | ||||
| .Bd -literal -offset indent | ||||
| SPLAY_FOREACH(var, NAME, head) { | ||||
| 	SPLAY_REMOVE(NAME, head, var); | ||||
| 	free(var); | ||||
| } | ||||
| free(head); | ||||
| .Ed | ||||
| .Pp | ||||
| Since | ||||
| .Va var | ||||
| is freed, the | ||||
| .Fn FOREACH | ||||
| macro refers to a pointer that may have been reallocated already. | ||||
| Proper code needs a second variable. | ||||
| .Bd -literal -offset indent | ||||
| for (var = SPLAY_MIN(NAME, head); var != NULL; var = nxt) { | ||||
| 	nxt = SPLAY_NEXT(NAME, head, var); | ||||
| 	SPLAY_REMOVE(NAME, head, var); | ||||
| 	free(var); | ||||
| } | ||||
| .Ed | ||||
| .Pp | ||||
| Both | ||||
| .Fn RB_INSERT | ||||
| and | ||||
| .Fn SPLAY_INSERT | ||||
| return | ||||
| .Dv NULL | ||||
| if the element was inserted in the tree successfully, otherwise they | ||||
| return a pointer to the element with the colliding key. | ||||
| .Pp | ||||
| Accordingly, | ||||
| .Fn RB_REMOVE | ||||
| and | ||||
| .Fn SPLAY_REMOVE | ||||
| return the pointer to the removed element otherwise they return | ||||
| .Dv NULL | ||||
| to indicate an error. | ||||
| .Sh SEE ALSO | ||||
| .Xr queue 3 | ||||
| .Sh AUTHORS | ||||
| The author of the tree macros is | ||||
| .An Niels Provos . | ||||
							
								
								
									
										198
									
								
								man/unvis.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										198
									
								
								man/unvis.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,198 @@ | ||||
| .\"	$OpenBSD: unvis.3,v 1.15 2005/07/22 03:16:58 jaredy Exp $ | ||||
| .\" | ||||
| .\" Copyright (c) 1989, 1991, 1993 | ||||
| .\"	The Regents of the University of California.  All rights reserved. | ||||
| .\" | ||||
| .\" 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. Neither the name of the University nor the names of its contributors | ||||
| .\"    may be used to endorse or promote products derived from this software | ||||
| .\"    without specific prior written permission. | ||||
| .\" | ||||
| .\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``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 REGENTS OR CONTRIBUTORS 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. | ||||
| .\" | ||||
| .Dd $Mdocdate: May 31 2007 $ | ||||
| .Dt UNVIS 3 | ||||
| .Os | ||||
| .Sh NAME | ||||
| .Nm unvis , | ||||
| .Nm strunvis , | ||||
| .Nm strnunvis | ||||
| .Nd decode a visual representation of characters | ||||
| .Sh LIBRARY | ||||
| .ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd) | ||||
| .Lb libbsd | ||||
| .Sh SYNOPSIS | ||||
| .In bsd/vis.h | ||||
| .Ft int | ||||
| .Fn unvis "char *cp" "char c" "int *astate" "int flag" | ||||
| .Ft int | ||||
| .Fn strunvis "char *dst" "char *src" | ||||
| .Ft ssize_t | ||||
| .Fn strnunvis "char *dst" "char *src" "size_t size" | ||||
| .Sh DESCRIPTION | ||||
| The | ||||
| .Fn unvis , | ||||
| .Fn strunvis | ||||
| and | ||||
| .Fn strnunvis | ||||
| functions are used to decode a visual representation of characters, | ||||
| as produced by the | ||||
| .Xr vis 3 | ||||
| function, back into the original form. | ||||
| .Fn unvis | ||||
| is called with successive characters in | ||||
| .Fa c | ||||
| until a valid | ||||
| sequence is recognized, at which time the decoded character is | ||||
| available at the character pointed to by | ||||
| .Fa cp . | ||||
| .Pp | ||||
| .Fn strunvis | ||||
| decodes the characters pointed to by | ||||
| .Fa src | ||||
| into the buffer pointed to by | ||||
| .Fa dst . | ||||
| .Pp | ||||
| .Fn strnunvis | ||||
| decodes the characters pointed to by | ||||
| .Fa src | ||||
| into the buffer pointed to by | ||||
| .Fa dst , | ||||
| writing a maximum of | ||||
| .Fa size | ||||
| bytes. | ||||
| The | ||||
| .Fn strunvis | ||||
| function simply copies | ||||
| .Fa src | ||||
| to | ||||
| .Fa dst , | ||||
| decoding any escape sequences along the way, | ||||
| and returns the number of characters placed into | ||||
| .Fa dst , | ||||
| or \-1 if an | ||||
| invalid escape sequence was detected. | ||||
| The size of | ||||
| .Fa dst | ||||
| should be | ||||
| equal to the size of | ||||
| .Fa src | ||||
| (that is, no expansion takes place during decoding). | ||||
| .Fn strunvis | ||||
| terminates the destination string with a trailing NUL byte; | ||||
| .Fn strnunvis | ||||
| does so if | ||||
| .Fa size | ||||
| is larger than 0. | ||||
| .Pp | ||||
| The | ||||
| .Fn unvis | ||||
| function implements a state machine that can be used to decode an arbitrary | ||||
| stream of bytes. | ||||
| All state associated with the bytes being decoded is stored outside the | ||||
| .Fn unvis | ||||
| function (that is, a pointer to the state is passed in), so | ||||
| calls decoding different streams can be freely intermixed. | ||||
| To start decoding a stream of bytes, first initialize an integer | ||||
| to zero. | ||||
| Call | ||||
| .Fn unvis | ||||
| with each successive byte, along with a pointer | ||||
| to this integer, and a pointer to a destination character. | ||||
| .Sh RETURN VALUES | ||||
| The | ||||
| .Fn unvis | ||||
| function has several return codes that must be handled properly. | ||||
| They are: | ||||
| .Bl -tag -width UNVIS_VALIDPUSH | ||||
| .It Li \&0 (zero) | ||||
| Another character is necessary; nothing has been recognized yet. | ||||
| .It Dv UNVIS_VALID | ||||
| A valid character has been recognized and is available at the location | ||||
| pointed to by | ||||
| .Fa cp . | ||||
| .It Dv UNVIS_VALIDPUSH | ||||
| A valid character has been recognized and is available at the location | ||||
| pointed to by | ||||
| .Fa cp ; | ||||
| however, the character currently passed in should be passed in again. | ||||
| .It Dv UNVIS_NOCHAR | ||||
| A valid sequence was detected, but no character was produced. | ||||
| This return code is necessary to indicate a logical break between characters. | ||||
| .It Dv UNVIS_SYNBAD | ||||
| An invalid escape sequence was detected, or the decoder is in an | ||||
| unknown state. | ||||
| The decoder is placed into the starting state. | ||||
| .El | ||||
| .Pp | ||||
| When all bytes in the stream have been processed, call | ||||
| .Fn unvis | ||||
| one more time with | ||||
| .Fa flag | ||||
| set to | ||||
| .Dv UNVIS_END | ||||
| to extract any remaining character (the character passed in is ignored). | ||||
| .Pp | ||||
| The | ||||
| .Fn strunvis | ||||
| function returns the number of bytes written (not counting | ||||
| the trailing NUL byte) or \-1 if an error occurred. | ||||
| .Pp | ||||
| The | ||||
| .Fn strnunvis | ||||
| function returns the number of bytes (not counting the trailing NUL byte) | ||||
| that would be needed to fully convert the input string, or \-1 if an | ||||
| error occurred. | ||||
| .Sh EXAMPLES | ||||
| The following code fragment illustrates a proper use of | ||||
| .Fn unvis . | ||||
| .Bd -literal -offset indent | ||||
| int state = 0; | ||||
| char out; | ||||
|  | ||||
| while ((ch = getchar()) != EOF) { | ||||
| again: | ||||
| 	switch(unvis(&out, ch, &state, 0)) { | ||||
| 	case 0: | ||||
| 	case UNVIS_NOCHAR: | ||||
| 		break; | ||||
| 	case UNVIS_VALID: | ||||
| 		(void) putchar(out); | ||||
| 		break; | ||||
| 	case UNVIS_VALIDPUSH: | ||||
| 		(void) putchar(out); | ||||
| 		goto again; | ||||
| 	case UNVIS_SYNBAD: | ||||
| 		(void)fprintf(stderr, "bad sequence!\en"); | ||||
| 		exit(1); | ||||
| 	} | ||||
| } | ||||
| if (unvis(&out, (char)0, &state, UNVIS_END) == UNVIS_VALID) | ||||
| 	(void) putchar(out); | ||||
| .Ed | ||||
| .Sh SEE ALSO | ||||
| .Xr unvis 1 , | ||||
| .Xr vis 1 , | ||||
| .Xr vis 3 | ||||
| .Sh HISTORY | ||||
| The | ||||
| .Fn unvis | ||||
| function first appeared in | ||||
| .Bx 4.4 . | ||||
							
								
								
									
										321
									
								
								man/vis.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										321
									
								
								man/vis.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,321 @@ | ||||
| .\"	$OpenBSD: vis.3,v 1.23 2005/08/28 19:51:27 millert Exp $ | ||||
| .\" | ||||
| .\" Copyright (c) 1989, 1991, 1993 | ||||
| .\"	The Regents of the University of California.  All rights reserved. | ||||
| .\" | ||||
| .\" 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. Neither the name of the University nor the names of its contributors | ||||
| .\"    may be used to endorse or promote products derived from this software | ||||
| .\"    without specific prior written permission. | ||||
| .\" | ||||
| .\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``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 REGENTS OR CONTRIBUTORS 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. | ||||
| .\" | ||||
| .Dd $Mdocdate: May 31 2007 $ | ||||
| .Dt VIS 3 | ||||
| .Os | ||||
| .Sh NAME | ||||
| .Nm vis , | ||||
| .Nm strvis , | ||||
| .Nm strnvis , | ||||
| .Nm strvisx | ||||
| .Nd visually encode characters | ||||
| .Sh LIBRARY | ||||
| .ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd) | ||||
| .Lb libbsd | ||||
| .Sh SYNOPSIS | ||||
| .In stdlib.h | ||||
| .In bsd/vis.h | ||||
| .Ft char * | ||||
| .Fn vis "char *dst" "int c" "int flag" "int nextc" | ||||
| .Ft int | ||||
| .Fn strvis "char *dst" "const char *src" "int flag" | ||||
| .Ft int | ||||
| .Fn strnvis "char *dst" "const char *src" "size_t size" "int flag" | ||||
| .Ft int | ||||
| .Fn strvisx "char *dst" "const char *src" "size_t len" "int flag" | ||||
| .Sh DESCRIPTION | ||||
| The | ||||
| .Fn vis | ||||
| function copies into | ||||
| .Fa dst | ||||
| a string which represents the character | ||||
| .Fa c . | ||||
| If | ||||
| .Fa c | ||||
| needs no encoding, it is copied in unaltered. | ||||
| The string is NUL terminated and a pointer to the end of the string is | ||||
| returned. | ||||
| The maximum length of any encoding is four | ||||
| characters (not including the trailing NUL); | ||||
| thus, when | ||||
| encoding a set of characters into a buffer, the size of the buffer should | ||||
| be four times the number of characters encoded, plus one for the trailing | ||||
| NUL. | ||||
| The | ||||
| .Fa flag | ||||
| parameter is used for altering the default range of | ||||
| characters considered for encoding and for altering the visual | ||||
| representation. | ||||
| The additional character, | ||||
| .Fa nextc , | ||||
| is only used when selecting the | ||||
| .Dv VIS_CSTYLE | ||||
| encoding format (explained below). | ||||
| .Pp | ||||
| The | ||||
| .Fn strvis , | ||||
| .Fn strnvis | ||||
| and | ||||
| .Fn strvisx | ||||
| functions copy into | ||||
| .Fa dst | ||||
| a visual representation of | ||||
| the string | ||||
| .Fa src . | ||||
| The | ||||
| .Fn strvis | ||||
| function encodes characters from | ||||
| .Fa src | ||||
| up to the first NUL. | ||||
| The | ||||
| .Fn strnvis | ||||
| function encodes characters from | ||||
| .Fa src | ||||
| up to the first NUL or the end of | ||||
| .Fa dst , | ||||
| as indicated by | ||||
| .Fa size . | ||||
| The | ||||
| .Fn strvisx | ||||
| function encodes exactly | ||||
| .Fa len | ||||
| characters from | ||||
| .Fa src | ||||
| (this | ||||
| is useful for encoding a block of data that may contain NULs). | ||||
| All three forms NUL terminate | ||||
| .Fa dst , | ||||
| except for | ||||
| .Fn strnvis | ||||
| when | ||||
| .Fa size | ||||
| is zero, in which case | ||||
| .Fa dst | ||||
| is not touched. | ||||
| For | ||||
| .Fn strvis | ||||
| and | ||||
| .Fn strvisx , | ||||
| the size of | ||||
| .Fa dst | ||||
| must be four times the number | ||||
| of characters encoded from | ||||
| .Fa src | ||||
| (plus one for the NUL). | ||||
| .Fn strvis | ||||
| and | ||||
| .Fn strvisx | ||||
| return the number of characters in | ||||
| .Fa dst | ||||
| (not including the trailing NUL). | ||||
| .Fn strnvis | ||||
| returns the length that | ||||
| .Fa dst | ||||
| would become if it were of unlimited size (similar to | ||||
| .Xr snprintf 3 | ||||
| or | ||||
| .Xr strlcpy 3 ) . | ||||
| This can be used to detect truncation but it also means that | ||||
| the return value of | ||||
| .Fn strnvis | ||||
| must not be used without checking it against | ||||
| .Fa size . | ||||
| .Pp | ||||
| The encoding is a unique, invertible representation composed entirely of | ||||
| graphic characters; it can be decoded back into the original form using | ||||
| the | ||||
| .Xr unvis 3 | ||||
| or | ||||
| .Xr strunvis 3 | ||||
| functions. | ||||
| .Pp | ||||
| There are two parameters that can be controlled: the range of | ||||
| characters that are encoded, and the type | ||||
| of representation used. | ||||
| By default, all non-graphic characters | ||||
| except space, tab, and newline are encoded | ||||
| (see | ||||
| .Xr isgraph 3 ) . | ||||
| The following flags | ||||
| alter this: | ||||
| .Bl -tag -width VIS_WHITEX | ||||
| .It Dv VIS_GLOB | ||||
| Also encode magic characters recognized by | ||||
| .Xr glob 3 | ||||
| .Pf ( Ql * , | ||||
| .Ql \&? , | ||||
| .Ql \&[ ) | ||||
| and | ||||
| .Ql # . | ||||
| .It Dv VIS_SP | ||||
| Also encode space. | ||||
| .It Dv VIS_TAB | ||||
| Also encode tab. | ||||
| .It Dv VIS_NL | ||||
| Also encode newline. | ||||
| .It Dv VIS_WHITE | ||||
| Synonym for | ||||
| .Dv VIS_SP | ||||
| \&| | ||||
| .Dv VIS_TAB | ||||
| \&| | ||||
| .Dv VIS_NL . | ||||
| .It Dv VIS_SAFE | ||||
| Only encode | ||||
| .Dq unsafe | ||||
| characters. | ||||
| These are control characters which may cause common terminals to perform | ||||
| unexpected functions. | ||||
| Currently this form allows space, | ||||
| tab, newline, backspace, bell, and return -- in addition | ||||
| to all graphic characters -- unencoded. | ||||
| .El | ||||
| .Pp | ||||
| There are three forms of encoding. | ||||
| All forms use the backslash | ||||
| .Ql \e | ||||
| character to introduce a special | ||||
| sequence; two backslashes are used to represent a real backslash. | ||||
| These are the visual formats: | ||||
| .Bl -tag -width VIS_CSTYLE | ||||
| .It (default) | ||||
| Use an | ||||
| .Ql M | ||||
| to represent meta characters (characters with the 8th | ||||
| bit set), and use a caret | ||||
| .Ql ^ | ||||
| to represent control characters (see | ||||
| .Xr iscntrl 3 ) . | ||||
| The following formats are used: | ||||
| .Bl -tag -width xxxxx | ||||
| .It Dv \e^C | ||||
| Represents the control character | ||||
| .Ql C . | ||||
| Spans characters | ||||
| .Ql \e000 | ||||
| through | ||||
| .Ql \e037 , | ||||
| and | ||||
| .Ql \e177 | ||||
| (as | ||||
| .Ql \e^? ) . | ||||
| .It Dv \eM-C | ||||
| Represents character | ||||
| .Ql C | ||||
| with the 8th bit set. | ||||
| Spans characters | ||||
| .Ql \e241 | ||||
| through | ||||
| .Ql \e376 . | ||||
| .It Dv \eM^C | ||||
| Represents control character | ||||
| .Ql C | ||||
| with the 8th bit set. | ||||
| Spans characters | ||||
| .Ql \e200 | ||||
| through | ||||
| .Ql \e237 , | ||||
| and | ||||
| .Ql \e377 | ||||
| (as | ||||
| .Ql \eM^? ) . | ||||
| .It Dv \e040 | ||||
| Represents | ||||
| .Tn ASCII | ||||
| space. | ||||
| .It Dv \e240 | ||||
| Represents Meta-space. | ||||
| .El | ||||
| .Pp | ||||
| .It Dv VIS_CSTYLE | ||||
| Use C-style backslash sequences to represent standard non-printable | ||||
| characters. | ||||
| The following sequences are used to represent the indicated characters: | ||||
| .Bd -unfilled -offset indent | ||||
| .Li \ea Tn  - BEL No (007) | ||||
| .Li \eb Tn  - BS No (010) | ||||
| .Li \ef Tn  - NP No (014) | ||||
| .Li \en Tn  - NL No (012) | ||||
| .Li \er Tn  - CR No (015) | ||||
| .Li \es Tn  - SP No (040) | ||||
| .Li \et Tn  - HT No (011) | ||||
| .Li \ev Tn  - VT No (013) | ||||
| .Li \e0 Tn  - NUL No (000) | ||||
| .Ed | ||||
| .Pp | ||||
| When using this format, the | ||||
| .Fa nextc | ||||
| parameter is looked at to determine | ||||
| if a NUL character can be encoded as | ||||
| .Ql \e0 | ||||
| instead of | ||||
| .Ql \e000 . | ||||
| If | ||||
| .Fa nextc | ||||
| is an octal digit, the latter representation is used to | ||||
| avoid ambiguity. | ||||
| .It Dv VIS_OCTAL | ||||
| Use a three digit octal sequence. | ||||
| The form is | ||||
| .Ql \eddd | ||||
| where | ||||
| .Ar d | ||||
| represents an octal digit. | ||||
| .El | ||||
| .Pp | ||||
| There is one additional flag, | ||||
| .Dv VIS_NOSLASH , | ||||
| which inhibits the | ||||
| doubling of backslashes and the backslash before the default | ||||
| format (that is, control characters are represented by | ||||
| .Ql ^C | ||||
| and | ||||
| meta characters as | ||||
| .Ql M-C ) . | ||||
| With this flag set, the encoding is | ||||
| ambiguous and non-invertible. | ||||
| .Sh SEE ALSO | ||||
| .Xr unvis 1 , | ||||
| .Xr vis 1 , | ||||
| .Xr snprintf 3 , | ||||
| .Xr strlcpy 3 , | ||||
| .Xr unvis 3 | ||||
| .Sh HISTORY | ||||
| The | ||||
| .Fn vis , | ||||
| .Fn strvis | ||||
| and | ||||
| .Fn strvisx | ||||
| functions first appeared in | ||||
| .Bx 4.4 . | ||||
| The | ||||
| .Fn strnvis | ||||
| function first appeared in | ||||
| .Ox 2.9 . | ||||
							
								
								
									
										1
									
								
								man/wcslcat.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								man/wcslcat.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| .so man3/wcslcpy.3 | ||||
							
								
								
									
										67
									
								
								man/wcslcpy.3
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										67
									
								
								man/wcslcpy.3
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,67 @@ | ||||
| .\"	$NetBSD: wmemchr.3,v 1.4 2001/01/02 11:26:23 itojun Exp $ | ||||
| .\" | ||||
| .\" Copyright (c) 1990, 1991, 1993 | ||||
| .\"	The Regents of the University of California.  All rights reserved. | ||||
| .\" | ||||
| .\" This code is derived from software contributed to Berkeley by | ||||
| .\" Chris Torek and the American National Standards Committee X3, | ||||
| .\" on Information Processing Systems. | ||||
| .\" | ||||
| .\" 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. Neither the name of the University nor the names of its contributors | ||||
| .\"    may be used to endorse or promote products derived from this software | ||||
| .\"    without specific prior written permission. | ||||
| .\" | ||||
| .\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``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 REGENTS OR CONTRIBUTORS 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. | ||||
| .\" | ||||
| .\"     from: @(#)strcpy.3	8.1 (Berkeley) 6/4/93 | ||||
| .\" | ||||
| .\" $FreeBSD$ | ||||
| .\" | ||||
| .Dd March 4, 2009 | ||||
| .Dt WCSLCPY 3 | ||||
| .Os | ||||
| .Sh NAME | ||||
| .Nm wcslcat , | ||||
| .Nm wcslcpy , | ||||
| .Nd wide character string manipulation operations | ||||
| .Sh LIBRARY | ||||
| .ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd) | ||||
| .Lb libbsd | ||||
| .Sh SYNOPSIS | ||||
| .In bsd/wchar.h | ||||
| .Ft size_t | ||||
| .Fn wcslcat "wchar_t *s1" "const wchar_t *s2" "size_t n" | ||||
| .Ft size_t | ||||
| .Fn wcslcpy "wchar_t *s1" "const wchar_t *s2" "size_t n" | ||||
| .Sh DESCRIPTION | ||||
| The functions implement string manipulation operations over wide character | ||||
| strings. | ||||
| For a detailed description, refer to documents for the respective single-byte | ||||
| counterpart, such as | ||||
| .Xr strlcpy 3 . | ||||
| .Sh SEE ALSO | ||||
| .Xr strlcat 3 , | ||||
| .Xr strlcpy 3 , | ||||
| .Sh STANDARDS | ||||
| .Fn wcslcat | ||||
| and | ||||
| .Fn wcslcpy , | ||||
| which are BSD extensions. | ||||
							
								
								
									
										92
									
								
								src/Makefile.am
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										92
									
								
								src/Makefile.am
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,92 @@ | ||||
| ## Process this file with automake to produce Makefile.in | ||||
|  | ||||
| AM_CPPFLAGS = \ | ||||
| 	-I$(top_builddir) \ | ||||
| 	-isystem $(top_srcdir)/include/bsd/ \ | ||||
| 	-include $(top_builddir)/config.h \ | ||||
| 	-DLIBBSD_OVERLAY -DLIBBSD_DISABLE_DEPRECATED \ | ||||
| 	-D__REENTRANT | ||||
|  | ||||
| EXTRA_DIST = \ | ||||
| 	libbsd.map \ | ||||
| 	libbsd.pc.in \ | ||||
| 	libbsd-overlay.pc.in \ | ||||
| 	hash/helper.c \ | ||||
| 	$(nil) | ||||
|  | ||||
| CLEANFILES = \ | ||||
| 	hash/md5hl.c \ | ||||
| 	$(nil) | ||||
|  | ||||
| pkgconfigdir = $(libdir)/pkgconfig | ||||
| pkgconfig_DATA = \ | ||||
| 	libbsd.pc \ | ||||
| 	libbsd-overlay.pc \ | ||||
| 	$(nil) | ||||
|  | ||||
| lib_LTLIBRARIES = libbsd.la | ||||
|  | ||||
| hash/md5hl.c: $(srcdir)/hash/helper.c | ||||
| 	$(AM_V_at) $(MKDIR_P) hash | ||||
| 	$(AM_V_GEN) sed -e 's:hashinc:md5.h:g' -e 's:HASH:MD5:g' $< > $@ | ||||
|  | ||||
| libbsd_la_DEPENDENCIES = \ | ||||
| 	libbsd.map | ||||
| libbsd_la_LDFLAGS = \ | ||||
| 	-Wl,--version-script=$(srcdir)/libbsd.map \ | ||||
| 	-version-number 0:5:1 | ||||
| libbsd_la_SOURCES = \ | ||||
| 	arc4random.c \ | ||||
| 	bsd_getopt.c \ | ||||
| 	closefrom.c \ | ||||
| 	dehumanize_number.c \ | ||||
| 	err.c \ | ||||
| 	expand_number.c \ | ||||
| 	fgetln.c \ | ||||
| 	fgetwln.c \ | ||||
| 	flopen.c \ | ||||
| 	fmtcheck.c \ | ||||
| 	fparseln.c \ | ||||
| 	fpurge.c \ | ||||
| 	getpeereid.c \ | ||||
| 	hash/md5.c \ | ||||
| 	hash/md5hl.c \ | ||||
| 	heapsort.c \ | ||||
| 	humanize_number.c \ | ||||
| 	inet_net_pton.c \ | ||||
| 	local-elf.h \ | ||||
| 	merge.c \ | ||||
| 	nlist.c \ | ||||
| 	pidfile.c \ | ||||
| 	progname.c \ | ||||
| 	radixsort.c \ | ||||
| 	readpassphrase.c \ | ||||
| 	reallocf.c \ | ||||
| 	setmode.c \ | ||||
| 	setproctitle.c \ | ||||
| 	strlcat.c \ | ||||
| 	strlcpy.c \ | ||||
| 	strmode.c \ | ||||
| 	strnstr.c \ | ||||
| 	strtonum.c \ | ||||
| 	unvis.c \ | ||||
| 	vis.c \ | ||||
| 	wcslcat.c \ | ||||
| 	wcslcpy.c \ | ||||
| 	$(nil) | ||||
|  | ||||
| runtimelibdir = $(libdir) | ||||
|  | ||||
| install-exec-hook: | ||||
| 	if [ "$(libdir)" != "$(runtimelibdir)" ]; then \ | ||||
| 		$(MKDIR_P) $(DESTDIR)$(runtimelibdir); \ | ||||
| 		mv $(DESTDIR)$(libdir)/libbsd*.so.* \ | ||||
| 		   $(DESTDIR)$(runtimelibdir)/; \ | ||||
| 		soname=`readlink $(DESTDIR)$(libdir)/libbsd.so`; \ | ||||
| 		sorelprefix=`echo $(libdir) | sed -r -e 's:(^/)?[^/]+:..:g'`; \ | ||||
| 		ln -sf $$sorelprefix$(runtimelibdir)/$$soname \ | ||||
| 		       $(DESTDIR)$(libdir)/libbsd.so; \ | ||||
| 	fi | ||||
|  | ||||
| uninstall-hook: | ||||
| 	rm -f $(DESTDIR)$(runtimelibdir)/libbsd*.so* | ||||
							
								
								
									
										195
									
								
								src/arc4random.c
									
									
									
									
									
								
							
							
						
						
									
										195
									
								
								src/arc4random.c
									
									
									
									
									
								
							| @@ -1,14 +1,23 @@ | ||||
| /* | ||||
|  * Arc4 random number generator for OpenBSD. | ||||
|  * Copyright 1996 David Mazieres <dm@lcs.mit.edu>. | ||||
|  * Copyright (c) 1996, David Mazieres <dm@uun.org> | ||||
|  * Copyright (c) 2008, Damien Miller <djm@openbsd.org> | ||||
|  * | ||||
|  * Modification and redistribution in source and binary forms is | ||||
|  * permitted provided that due credit is given to the author and the | ||||
|  * OpenBSD project (for instance by leaving this copyright notice | ||||
|  * intact). | ||||
|  * Permission to use, copy, modify, and distribute this software for any | ||||
|  * purpose with or without fee is hereby granted, provided that the above | ||||
|  * copyright notice and this permission notice appear in all copies. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | ||||
|  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | ||||
|  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | ||||
|  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | ||||
|  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | ||||
|  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF | ||||
|  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||||
|  */ | ||||
|  | ||||
| /* | ||||
|  * Arc4 random number generator for OpenBSD. | ||||
|  * | ||||
|  * This code is derived from section 17.1 of Applied Cryptography, | ||||
|  * second edition, which describes a stream cipher allegedly | ||||
|  * compatible with RSA Labs "RC4" cipher (the actual description of | ||||
| @@ -24,7 +33,7 @@ | ||||
|  */ | ||||
|  | ||||
| #include <sys/cdefs.h> | ||||
| __FBSDID("$FreeBSD: src/lib/libc/gen/arc4random.c,v 1.10 2004/03/24 14:44:57 green Exp $"); | ||||
| __FBSDID("$FreeBSD$"); | ||||
|  | ||||
| #include <sys/types.h> | ||||
| #include <sys/time.h> | ||||
| @@ -40,6 +49,8 @@ struct arc4_stream { | ||||
| }; | ||||
|  | ||||
| #define	RANDOMDEV	"/dev/urandom" | ||||
| #define KEYSIZE		128 | ||||
|  | ||||
| #ifdef __REENTRANT | ||||
| static pthread_mutex_t arc4random_mtx = PTHREAD_MUTEX_INITIALIZER; | ||||
| #define	THREAD_LOCK()	pthread_mutex_lock(&arc4random_mtx) | ||||
| @@ -52,58 +63,63 @@ static pthread_mutex_t arc4random_mtx = PTHREAD_MUTEX_INITIALIZER; | ||||
| static struct arc4_stream rs; | ||||
| static int rs_initialized; | ||||
| static int rs_stired; | ||||
| static int arc4_count; | ||||
|  | ||||
| static inline u_int8_t arc4_getbyte(struct arc4_stream *); | ||||
| static void arc4_stir(struct arc4_stream *); | ||||
| static inline u_int8_t arc4_getbyte(void); | ||||
| static void arc4_stir(void); | ||||
|  | ||||
| static inline void | ||||
| arc4_init(struct arc4_stream *as) | ||||
| arc4_init(void) | ||||
| { | ||||
| 	int     n; | ||||
|  | ||||
| 	for (n = 0; n < 256; n++) | ||||
| 		as->s[n] = n; | ||||
| 	as->i = 0; | ||||
| 	as->j = 0; | ||||
| 		rs.s[n] = n; | ||||
| 	rs.i = 0; | ||||
| 	rs.j = 0; | ||||
| } | ||||
|  | ||||
| static inline void | ||||
| arc4_addrandom(struct arc4_stream *as, u_char *dat, int datlen) | ||||
| arc4_addrandom(u_char *dat, int datlen) | ||||
| { | ||||
| 	int     n; | ||||
| 	u_int8_t si; | ||||
|  | ||||
| 	as->i--; | ||||
| 	rs.i--; | ||||
| 	for (n = 0; n < 256; n++) { | ||||
| 		as->i = (as->i + 1); | ||||
| 		si = as->s[as->i]; | ||||
| 		as->j = (as->j + si + dat[n % datlen]); | ||||
| 		as->s[as->i] = as->s[as->j]; | ||||
| 		as->s[as->j] = si; | ||||
| 		rs.i = (rs.i + 1); | ||||
| 		si = rs.s[rs.i]; | ||||
| 		rs.j = (rs.j + si + dat[n % datlen]); | ||||
| 		rs.s[rs.i] = rs.s[rs.j]; | ||||
| 		rs.s[rs.j] = si; | ||||
| 	} | ||||
| 	rs.j = rs.i; | ||||
| } | ||||
|  | ||||
| static void | ||||
| arc4_stir(struct arc4_stream *as) | ||||
| arc4_stir(void) | ||||
| { | ||||
| 	int     fd, n; | ||||
| 	int done, fd, n; | ||||
| 	struct { | ||||
| 		struct timeval tv; | ||||
| 		pid_t pid; | ||||
| 		u_int8_t rnd[128 - sizeof(struct timeval) - sizeof(pid_t)]; | ||||
| 	}       rdat; | ||||
| 		struct timeval	tv; | ||||
| 		pid_t 		pid; | ||||
| 		u_int8_t 	rnd[KEYSIZE]; | ||||
| 	} rdat; | ||||
|  | ||||
| 	gettimeofday(&rdat.tv, NULL); | ||||
| 	rdat.pid = getpid(); | ||||
| 	fd = open(RANDOMDEV, O_RDONLY, 0); | ||||
| 	done = 0; | ||||
| 	if (fd >= 0) { | ||||
| 		(void) read(fd, rdat.rnd, sizeof(rdat.rnd)); | ||||
| 		close(fd); | ||||
| 		if (read(fd, &rdat, KEYSIZE) == KEYSIZE) | ||||
| 			done = 1; | ||||
| 		(void)close(fd); | ||||
| 	}  | ||||
| 	if (!done) { | ||||
| 		(void)gettimeofday(&rdat.tv, NULL); | ||||
| 		rdat.pid = getpid(); | ||||
| 		/* We'll just take whatever was on the stack too... */ | ||||
| 	} | ||||
| 	/* fd < 0?  Ah, what the heck. We'll just take whatever was on the | ||||
| 	 * stack... */ | ||||
|  | ||||
| 	arc4_addrandom(as, (void *) &rdat, sizeof(rdat)); | ||||
| 	arc4_addrandom((u_char *)&rdat, KEYSIZE); | ||||
|  | ||||
| 	/* | ||||
| 	 * Throw away the first N bytes of output, as suggested in the | ||||
| @@ -113,33 +129,34 @@ arc4_stir(struct arc4_stream *as) | ||||
| 	 * by Ilya Mironov. | ||||
| 	 */ | ||||
| 	for (n = 0; n < 1024; n++) | ||||
| 		arc4_getbyte(as); | ||||
| 		(void) arc4_getbyte(); | ||||
| 	arc4_count = 1600000; | ||||
| } | ||||
|  | ||||
| static inline u_int8_t | ||||
| arc4_getbyte(struct arc4_stream *as) | ||||
| arc4_getbyte(void) | ||||
| { | ||||
| 	u_int8_t si, sj; | ||||
|  | ||||
| 	as->i = (as->i + 1); | ||||
| 	si = as->s[as->i]; | ||||
| 	as->j = (as->j + si); | ||||
| 	sj = as->s[as->j]; | ||||
| 	as->s[as->i] = sj; | ||||
| 	as->s[as->j] = si; | ||||
| 	rs.i = (rs.i + 1); | ||||
| 	si = rs.s[rs.i]; | ||||
| 	rs.j = (rs.j + si); | ||||
| 	sj = rs.s[rs.j]; | ||||
| 	rs.s[rs.i] = sj; | ||||
| 	rs.s[rs.j] = si; | ||||
|  | ||||
| 	return (as->s[(si + sj) & 0xff]); | ||||
| 	return (rs.s[(si + sj) & 0xff]); | ||||
| } | ||||
|  | ||||
| static inline u_int32_t | ||||
| arc4_getword(struct arc4_stream *as) | ||||
| arc4_getword(void) | ||||
| { | ||||
| 	u_int32_t val; | ||||
|  | ||||
| 	val = arc4_getbyte(as) << 24; | ||||
| 	val |= arc4_getbyte(as) << 16; | ||||
| 	val |= arc4_getbyte(as) << 8; | ||||
| 	val |= arc4_getbyte(as); | ||||
| 	val = arc4_getbyte() << 24; | ||||
| 	val |= arc4_getbyte() << 16; | ||||
| 	val |= arc4_getbyte() << 8; | ||||
| 	val |= arc4_getbyte(); | ||||
|  | ||||
| 	return (val); | ||||
| } | ||||
| @@ -148,55 +165,115 @@ static void | ||||
| arc4_check_init(void) | ||||
| { | ||||
| 	if (!rs_initialized) { | ||||
| 		arc4_init(&rs); | ||||
| 		arc4_init(); | ||||
| 		rs_initialized = 1; | ||||
| 	} | ||||
| } | ||||
|  | ||||
| static void | ||||
| static inline void | ||||
| arc4_check_stir(void) | ||||
| { | ||||
| 	if (!rs_stired) { | ||||
| 		arc4_stir(&rs); | ||||
| 	if (!rs_stired || arc4_count <= 0) { | ||||
| 		arc4_stir(); | ||||
| 		rs_stired = 1; | ||||
| 	} | ||||
| } | ||||
|  | ||||
| void | ||||
| arc4random_stir() | ||||
| arc4random_stir(void) | ||||
| { | ||||
| 	THREAD_LOCK(); | ||||
| 	arc4_check_init(); | ||||
| 	arc4_stir(&rs); | ||||
| 	arc4_stir(); | ||||
| 	rs_stired = 1; | ||||
| 	THREAD_UNLOCK(); | ||||
| } | ||||
|  | ||||
| void | ||||
| arc4random_addrandom(dat, datlen) | ||||
| 	u_char *dat; | ||||
| 	int     datlen; | ||||
| arc4random_addrandom(u_char *dat, int datlen) | ||||
| { | ||||
| 	THREAD_LOCK(); | ||||
| 	arc4_check_init(); | ||||
| 	arc4_check_stir(); | ||||
| 	arc4_addrandom(&rs, dat, datlen); | ||||
| 	arc4_addrandom(dat, datlen); | ||||
| 	THREAD_UNLOCK(); | ||||
| } | ||||
|  | ||||
| u_int32_t | ||||
| arc4random() | ||||
| arc4random(void) | ||||
| { | ||||
| 	u_int32_t rnd; | ||||
|  | ||||
| 	THREAD_LOCK(); | ||||
| 	arc4_check_init(); | ||||
| 	arc4_check_stir(); | ||||
| 	rnd = arc4_getword(&rs); | ||||
| 	rnd = arc4_getword(); | ||||
| 	arc4_count -= 4; | ||||
| 	THREAD_UNLOCK(); | ||||
|  | ||||
| 	return (rnd); | ||||
| } | ||||
|  | ||||
| void | ||||
| arc4random_buf(void *_buf, size_t n) | ||||
| { | ||||
| 	u_char *buf = (u_char *)_buf; | ||||
|  | ||||
| 	THREAD_LOCK(); | ||||
| 	arc4_check_init(); | ||||
| 	while (n--) { | ||||
| 		arc4_check_stir(); | ||||
| 		buf[n] = arc4_getbyte(); | ||||
| 		arc4_count--; | ||||
| 	} | ||||
| 	THREAD_UNLOCK(); | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * Calculate a uniformly distributed random number less than upper_bound | ||||
|  * avoiding "modulo bias". | ||||
|  * | ||||
|  * Uniformity is achieved by generating new random numbers until the one | ||||
|  * returned is outside the range [0, 2**32 % upper_bound).  This | ||||
|  * guarantees the selected random number will be inside | ||||
|  * [2**32 % upper_bound, 2**32) which maps back to [0, upper_bound) | ||||
|  * after reduction modulo upper_bound. | ||||
|  */ | ||||
| u_int32_t | ||||
| arc4random_uniform(u_int32_t upper_bound) | ||||
| { | ||||
| 	u_int32_t r, min; | ||||
|  | ||||
| 	if (upper_bound < 2) | ||||
| 		return (0); | ||||
|  | ||||
| #if (ULONG_MAX > 0xffffffffUL) | ||||
| 	min = 0x100000000UL % upper_bound; | ||||
| #else | ||||
| 	/* Calculate (2**32 % upper_bound) avoiding 64-bit math */ | ||||
| 	if (upper_bound > 0x80000000) | ||||
| 		min = 1 + ~upper_bound;		/* 2**32 - upper_bound */ | ||||
| 	else { | ||||
| 		/* (2**32 - (x * 2)) % x == 2**32 % x when x <= 2**31 */ | ||||
| 		min = ((0xffffffff - (upper_bound * 2)) + 1) % upper_bound; | ||||
| 	} | ||||
| #endif | ||||
|  | ||||
| 	/* | ||||
| 	 * This could theoretically loop forever but each retry has | ||||
| 	 * p > 0.5 (worst case, usually far better) of selecting a | ||||
| 	 * number inside the range we need, so it should rarely need | ||||
| 	 * to re-roll. | ||||
| 	 */ | ||||
| 	for (;;) { | ||||
| 		r = arc4random(); | ||||
| 		if (r >= min) | ||||
| 			break; | ||||
| 	} | ||||
|  | ||||
| 	return (r % upper_bound); | ||||
| } | ||||
|  | ||||
| #if 0 | ||||
| /*-------- Test code for i386 --------*/ | ||||
| #include <stdio.h> | ||||
|   | ||||
| @@ -24,18 +24,21 @@ | ||||
|  * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  */ | ||||
|  | ||||
| #include <bsd/getopt.h> | ||||
| #include <getopt.h> | ||||
|  | ||||
| int optreset = 0; | ||||
|  | ||||
| int | ||||
| bsd_getopt (int argc, char **argv, char *shortopts) | ||||
| bsd_getopt(int argc, char * const argv[], const char *shortopts) | ||||
| { | ||||
|   if (optreset == 1) | ||||
|     { | ||||
|       optreset = 0; | ||||
|       optind = 0; | ||||
|     } | ||||
| 	if (optreset == 1) { | ||||
| 		optreset = 0; | ||||
| 		optind = 0; | ||||
| 	} | ||||
|  | ||||
|   return getopt (argc, argv, shortopts); | ||||
| 	/* | ||||
| 	 * Make sure we are using the system getopt() and not a possible | ||||
| 	 * overlay macro. | ||||
| 	 */ | ||||
| 	return (getopt)(argc, argv, shortopts); | ||||
| } | ||||
|   | ||||
							
								
								
									
										122
									
								
								src/closefrom.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										122
									
								
								src/closefrom.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,122 @@ | ||||
| /* | ||||
|  * Copyright (c) 2004-2005, 2007, 2010 | ||||
|  *	Todd C. Miller <Todd.Miller@courtesan.com> | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this software for any | ||||
|  * purpose with or without fee is hereby granted, provided that the above | ||||
|  * copyright notice and this permission notice appear in all copies. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | ||||
|  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | ||||
|  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | ||||
|  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | ||||
|  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | ||||
|  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF | ||||
|  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||||
|  */ | ||||
|  | ||||
| #include <config.h> | ||||
|  | ||||
| #include <sys/types.h> | ||||
| #include <sys/param.h> | ||||
| #include <unistd.h> | ||||
| #include <stdio.h> | ||||
| #ifdef STDC_HEADERS | ||||
| # include <stdlib.h> | ||||
| # include <stddef.h> | ||||
| #else | ||||
| # ifdef HAVE_STDLIB_H | ||||
| #  include <stdlib.h> | ||||
| # endif | ||||
| #endif /* STDC_HEADERS */ | ||||
| #include <fcntl.h> | ||||
| #ifdef HAVE_DIRENT_H | ||||
| # include <dirent.h> | ||||
| # define NAMLEN(dirent) strlen((dirent)->d_name) | ||||
| #else | ||||
| # define dirent direct | ||||
| # define NAMLEN(dirent) (dirent)->d_namlen | ||||
| # ifdef HAVE_SYS_NDIR_H | ||||
| #  include <sys/ndir.h> | ||||
| # endif | ||||
| # ifdef HAVE_SYS_DIR_H | ||||
| #  include <sys/dir.h> | ||||
| # endif | ||||
| # ifdef HAVE_NDIR_H | ||||
| #  include <ndir.h> | ||||
| # endif | ||||
| #endif | ||||
|  | ||||
| #ifndef OPEN_MAX | ||||
| # define OPEN_MAX 256 | ||||
| #endif | ||||
|  | ||||
| #ifndef HAVE_FCNTL_CLOSEM | ||||
| # ifndef HAVE_DIRFD | ||||
| #   define closefrom_fallback	closefrom | ||||
| # endif | ||||
| #endif | ||||
|  | ||||
| /* | ||||
|  * Close all file descriptors greater than or equal to lowfd. | ||||
|  * This is the expensive (ballback) method. | ||||
|  */ | ||||
| void | ||||
| closefrom_fallback(int lowfd) | ||||
| { | ||||
| 	long fd, maxfd; | ||||
|  | ||||
| 	/* | ||||
| 	 * Fall back on sysconf() or getdtablesize().  We avoid checking | ||||
| 	 * resource limits since it is possible to open a file descriptor | ||||
| 	 * and then drop the rlimit such that it is below the open fd. | ||||
| 	 */ | ||||
| #ifdef HAVE_SYSCONF | ||||
| 	maxfd = sysconf(_SC_OPEN_MAX); | ||||
| #else | ||||
| 	maxfd = getdtablesize(); | ||||
| #endif /* HAVE_SYSCONF */ | ||||
| 	if (maxfd < 0) | ||||
| 		maxfd = OPEN_MAX; | ||||
|  | ||||
| 	for (fd = lowfd; fd < maxfd; fd++) | ||||
| 		(void)close((int)fd); | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * Close all file descriptors greater than or equal to lowfd. | ||||
|  * We try the fast way first, falling back on the slow method. | ||||
|  */ | ||||
| #ifdef HAVE_FCNTL_CLOSEM | ||||
| void | ||||
| closefrom(int lowfd) | ||||
| { | ||||
| 	if (fcntl(lowfd, F_CLOSEM, 0) == -1) | ||||
| 		closefrom_fallback(lowfd); | ||||
| } | ||||
| #else | ||||
| # ifdef HAVE_DIRFD | ||||
| void | ||||
| closefrom(int lowfd) | ||||
| { | ||||
| 	struct dirent *dent; | ||||
| 	DIR *dirp; | ||||
| 	char *endp; | ||||
| 	long fd; | ||||
|  | ||||
| 	/* Use /proc/self/fd directory if it exists. */ | ||||
| 	dirp = opendir("/proc/self/fd"); | ||||
| 	if (dirp != NULL) { | ||||
| 		while ((dent = readdir(dirp)) != NULL) { | ||||
| 			fd = strtol(dent->d_name, &endp, 10); | ||||
| 			if (dent->d_name != endp && *endp == '\0' && | ||||
| 			    fd >= 0 && fd < INT_MAX && fd >= lowfd && | ||||
| 			    fd != dirfd(dirp)) | ||||
| 				(void)close((int)fd); | ||||
| 		} | ||||
| 		(void)closedir(dirp); | ||||
| 	} else | ||||
| 		closefrom_fallback(lowfd); | ||||
| } | ||||
| #endif /* HAVE_DIRFD */ | ||||
| #endif /* HAVE_FCNTL_CLOSEM */ | ||||
							
								
								
									
										62
									
								
								src/dehumanize_number.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										62
									
								
								src/dehumanize_number.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,62 @@ | ||||
| /* | ||||
|  * Copyright © 2012 Guillem Jover <guillem@hadrons.org> | ||||
|  * | ||||
|  * 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. | ||||
|  */ | ||||
|  | ||||
| #include <sys/cdefs.h> | ||||
|  | ||||
| #include <errno.h> | ||||
| #include <ctype.h> | ||||
| #include <libutil.h> | ||||
| #include <stdint.h> | ||||
| #include <stdlib.h> | ||||
|  | ||||
| int | ||||
| dehumanize_number(const char *buf, int64_t *num) | ||||
| { | ||||
| 	uint64_t rval; | ||||
| 	int sign = 1; | ||||
| 	int rc; | ||||
|  | ||||
| 	/* The current expand_number() implementation uses bit shifts, so | ||||
| 	 * we cannot pass negative numbers, preserve the sign and apply it | ||||
| 	 * later. */ | ||||
| 	while (isspace(*buf)) | ||||
| 		buf++; | ||||
| 	if (*buf == '-') { | ||||
| 		sign = -1; | ||||
| 		buf++; | ||||
| 	} | ||||
|  | ||||
| 	rc = expand_number(buf, &rval); | ||||
| 	if (rc < 0) | ||||
| 		return rc; | ||||
| 	if (rval == UINT64_MAX && sign == -1) { | ||||
| 		errno = ERANGE; | ||||
| 		return -1; | ||||
| 	} | ||||
| 	*num = rval * sign; | ||||
|  | ||||
| 	return 0; | ||||
| } | ||||
							
								
								
									
										45
									
								
								src/err.c
									
									
									
									
									
								
							
							
						
						
									
										45
									
								
								src/err.c
									
									
									
									
									
								
							| @@ -1,5 +1,6 @@ | ||||
| /* | ||||
|  * Copyright © 2006 Robert Millan | ||||
|  * Copyright © 2011 Guillem Jover <guillem@hadrons.org> | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
|  * modification, are permitted provided that the following conditions | ||||
| @@ -24,49 +25,43 @@ | ||||
|  * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||
|  */ | ||||
|  | ||||
| #include <bsd/err.h> | ||||
| #include <err.h> | ||||
| #include <errno.h> | ||||
| #include <stdarg.h> | ||||
|  | ||||
| void | ||||
| warnc (int code, const char *format, ...) | ||||
| warnc(int code, const char *format, ...) | ||||
| { | ||||
|   int tmp = errno; | ||||
|   va_list ap; | ||||
|   va_start (ap, format); | ||||
| 	va_list ap; | ||||
|  | ||||
|   errno = code; | ||||
|   warn (format, ap); | ||||
|   errno = tmp; | ||||
|  | ||||
|   va_end (ap); | ||||
| 	va_start(ap, format); | ||||
| 	vwarnc(code, format, ap); | ||||
| 	va_end(ap); | ||||
| } | ||||
|  | ||||
| void | ||||
| vwarnc (int code, const char *format, va_list ap) | ||||
| vwarnc(int code, const char *format, va_list ap) | ||||
| { | ||||
|   int tmp = errno; | ||||
| 	int tmp = errno; | ||||
|  | ||||
|   errno = code; | ||||
|   vwarn (format, ap); | ||||
|   errno = tmp; | ||||
| 	errno = code; | ||||
| 	vwarn(format, ap); | ||||
| 	errno = tmp; | ||||
| } | ||||
|  | ||||
| void | ||||
| errc (int status, int code, const char *format, ...) | ||||
| errc(int status, int code, const char *format, ...) | ||||
| { | ||||
|   va_list ap; | ||||
|   va_start (ap, format); | ||||
| 	va_list ap; | ||||
|  | ||||
|   errno = code; | ||||
|   err (status, format, ap); | ||||
|  | ||||
|   va_end (ap); | ||||
| 	va_start(ap, format); | ||||
| 	verrc(status, code, format, ap); | ||||
| 	va_end(ap); | ||||
| } | ||||
|  | ||||
| void | ||||
| verrc (int status, int code, const char *format, va_list ap) | ||||
| verrc(int status, int code, const char *format, va_list ap) | ||||
| { | ||||
|   errno = code; | ||||
|   verr (status, format, ap); | ||||
| 	errno = code; | ||||
| 	verr(status, format, ap); | ||||
| } | ||||
|   | ||||
							
								
								
									
										101
									
								
								src/expand_number.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										101
									
								
								src/expand_number.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,101 @@ | ||||
| /*- | ||||
|  * Copyright (c) 2007 Eric Anderson <anderson@FreeBSD.org> | ||||
|  * Copyright (c) 2007 Pawel Jakub Dawidek <pjd@FreeBSD.org> | ||||
|  * All rights reserved. | ||||
|  * | ||||
|  * 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. | ||||
|  * | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE AUTHORS AND CONTRIBUTORS ``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 AUTHORS OR CONTRIBUTORS 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. | ||||
|  */ | ||||
|  | ||||
| #include <sys/cdefs.h> | ||||
| __FBSDID("$FreeBSD$"); | ||||
|  | ||||
| #include <sys/types.h> | ||||
| #include <ctype.h> | ||||
| #include <errno.h> | ||||
| #include <inttypes.h> | ||||
| #include <libutil.h> | ||||
| #include <stdint.h> | ||||
|  | ||||
| /* | ||||
|  * Convert an expression of the following forms to a uint64_t. | ||||
|  *	1) A positive decimal number. | ||||
|  *	2) A positive decimal number followed by a 'b' or 'B' (mult by 1). | ||||
|  *	3) A positive decimal number followed by a 'k' or 'K' (mult by 1 << 10). | ||||
|  *	4) A positive decimal number followed by a 'm' or 'M' (mult by 1 << 20). | ||||
|  *	5) A positive decimal number followed by a 'g' or 'G' (mult by 1 << 30). | ||||
|  *	6) A positive decimal number followed by a 't' or 'T' (mult by 1 << 40). | ||||
|  *	7) A positive decimal number followed by a 'p' or 'P' (mult by 1 << 50). | ||||
|  *	8) A positive decimal number followed by a 'e' or 'E' (mult by 1 << 60). | ||||
|  */ | ||||
| int | ||||
| expand_number(const char *buf, uint64_t *num) | ||||
| { | ||||
| 	uint64_t number; | ||||
| 	unsigned shift; | ||||
| 	char *endptr; | ||||
|  | ||||
| 	number = strtoumax(buf, &endptr, 0); | ||||
|  | ||||
| 	if (endptr == buf) { | ||||
| 		/* No valid digits. */ | ||||
| 		errno = EINVAL; | ||||
| 		return (-1); | ||||
| 	} | ||||
|  | ||||
| 	switch (tolower((unsigned char)*endptr)) { | ||||
| 	case 'e': | ||||
| 		shift = 60; | ||||
| 		break; | ||||
| 	case 'p': | ||||
| 		shift = 50; | ||||
| 		break; | ||||
| 	case 't': | ||||
| 		shift = 40; | ||||
| 		break; | ||||
| 	case 'g': | ||||
| 		shift = 30; | ||||
| 		break; | ||||
| 	case 'm': | ||||
| 		shift = 20; | ||||
| 		break; | ||||
| 	case 'k': | ||||
| 		shift = 10; | ||||
| 		break; | ||||
| 	case 'b': | ||||
| 	case '\0': /* No unit. */ | ||||
| 		*num = number; | ||||
| 		return (0); | ||||
| 	default: | ||||
| 		/* Unrecognized unit. */ | ||||
| 		errno = EINVAL; | ||||
| 		return (-1); | ||||
| 	} | ||||
|  | ||||
| 	if ((number << shift) >> shift != number) { | ||||
| 		/* Overflow */ | ||||
| 		errno = ERANGE; | ||||
| 		return (-1); | ||||
| 	} | ||||
|  | ||||
| 	*num = number << shift; | ||||
| 	return (0); | ||||
| } | ||||
							
								
								
									
										38
									
								
								src/fgetln.c
									
									
									
									
									
								
							
							
						
						
									
										38
									
								
								src/fgetln.c
									
									
									
									
									
								
							| @@ -1,6 +1,6 @@ | ||||
| /* | ||||
|  * Copyright © 2005 Hector Garcia Alvarez | ||||
|  * Copyright © 2005, 2008, 2009 Guillem Jover | ||||
|  * Copyright © 2005, 2008-2012 Guillem Jover <guillem@hadrons.org> | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
|  * modification, are permitted provided that the following conditions | ||||
| @@ -30,22 +30,44 @@ | ||||
| #include <sys/types.h> | ||||
| #include <string.h> | ||||
|  | ||||
| #ifdef __GLIBC__ | ||||
| #ifdef HAVE_GETLINE | ||||
| struct filebuf { | ||||
| 	FILE *fp; | ||||
| 	char *buf; | ||||
| 	size_t len; | ||||
| }; | ||||
|  | ||||
| #define FILEBUF_POOL_ITEMS 32 | ||||
|  | ||||
| static struct filebuf fb_pool[FILEBUF_POOL_ITEMS]; | ||||
| static int fb_pool_cur; | ||||
|  | ||||
| char * | ||||
| fgetln (FILE *stream, size_t *len) | ||||
| fgetln(FILE *stream, size_t *len) | ||||
| { | ||||
| 	static char *line = NULL; | ||||
| 	static size_t line_len = 0; | ||||
| 	struct filebuf *fb; | ||||
| 	ssize_t nread; | ||||
|  | ||||
| 	nread = getline(&line, &line_len, stream); | ||||
| 	/* Try to diminish the possibility of several fgetln() calls being | ||||
| 	 * used on different streams, by using a pool of buffers per file. */ | ||||
| 	fb = &fb_pool[fb_pool_cur]; | ||||
| 	if (fb->fp != stream && fb->fp != NULL) { | ||||
| 		fb_pool_cur++; | ||||
| 		fb_pool_cur %= FILEBUF_POOL_ITEMS; | ||||
| 		fb = &fb_pool[fb_pool_cur]; | ||||
| 	} | ||||
| 	fb->fp = stream; | ||||
|  | ||||
| 	nread = getline(&fb->buf, &fb->len, stream); | ||||
| 	/* Note: the getdelim/getline API ensures nread != 0. */ | ||||
| 	if (nread == -1) { | ||||
| 		*len = 0; | ||||
| 		return NULL; | ||||
| 	} else { | ||||
| 		*len = (size_t)nread; | ||||
| 		return line; | ||||
| 		return fb->buf; | ||||
| 	} | ||||
| } | ||||
| #else | ||||
| #error "Function fgetln() needs to be ported." | ||||
| #endif | ||||
|  | ||||
|   | ||||
							
								
								
									
										87
									
								
								src/fgetwln.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										87
									
								
								src/fgetwln.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,87 @@ | ||||
| /* | ||||
|  * Copyright © 2012 Guillem Jover <guillem@hadrons.org> | ||||
|  * | ||||
|  * 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. | ||||
|  */ | ||||
|  | ||||
| #include <sys/cdefs.h> | ||||
|  | ||||
| #include <stdlib.h> | ||||
| #include <stdio.h> | ||||
| #include <wchar.h> | ||||
|  | ||||
| struct filewbuf { | ||||
| 	FILE *fp; | ||||
| 	wchar_t *wbuf; | ||||
| 	size_t len; | ||||
| }; | ||||
|  | ||||
| #define FILEWBUF_INIT_LEN	128 | ||||
| #define FILEWBUF_POOL_ITEMS	32 | ||||
|  | ||||
| static struct filewbuf fb_pool[FILEWBUF_POOL_ITEMS]; | ||||
| static int fb_pool_cur; | ||||
|  | ||||
| wchar_t * | ||||
| fgetwln(FILE *stream, size_t *lenp) | ||||
| { | ||||
| 	struct filewbuf *fb; | ||||
| 	wint_t wc; | ||||
| 	size_t wused = 0; | ||||
|  | ||||
| 	/* Try to diminish the possibility of several fgetwln() calls being | ||||
| 	 * used on different streams, by using a pool of buffers per file. */ | ||||
| 	fb = &fb_pool[fb_pool_cur]; | ||||
| 	if (fb->fp != stream && fb->fp != NULL) { | ||||
| 		fb_pool_cur++; | ||||
| 		fb_pool_cur %= FILEWBUF_POOL_ITEMS; | ||||
| 		fb = &fb_pool[fb_pool_cur]; | ||||
| 	} | ||||
| 	fb->fp = stream; | ||||
|  | ||||
| 	while ((wc = fgetwc(stream)) != WEOF) { | ||||
| 		if (!fb->len || wused > fb->len) { | ||||
| 			wchar_t *wp; | ||||
|  | ||||
| 			if (fb->len) | ||||
| 				fb->len *= 2; | ||||
| 			else | ||||
| 				fb->len = FILEWBUF_INIT_LEN; | ||||
|  | ||||
| 			wp = realloc(fb->wbuf, fb->len * sizeof(wchar_t)); | ||||
| 			if (wp == NULL) { | ||||
| 				wused = 0; | ||||
| 				break; | ||||
| 			} | ||||
| 			fb->wbuf = wp; | ||||
| 		} | ||||
|  | ||||
| 		fb->wbuf[wused++] = wc; | ||||
|  | ||||
| 		if (wc == L'\n') | ||||
| 			break; | ||||
| 	} | ||||
|  | ||||
| 	*lenp = wused; | ||||
| 	return wused ? fb->wbuf : NULL; | ||||
| } | ||||
							
								
								
									
										104
									
								
								src/flopen.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										104
									
								
								src/flopen.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,104 @@ | ||||
| /*- | ||||
|  * Copyright (c) 2007 Dag-Erling Coïdan Smørgrav | ||||
|  * All rights reserved. | ||||
|  * | ||||
|  * 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 | ||||
|  *    in this position and unchanged. | ||||
|  * 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. | ||||
|  * | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``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 OR CONTRIBUTORS 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. | ||||
|  */ | ||||
|  | ||||
| #include <sys/cdefs.h> | ||||
| __FBSDID("$FreeBSD$"); | ||||
|  | ||||
| #include <sys/file.h> | ||||
| #include <sys/stat.h> | ||||
|  | ||||
| #include <errno.h> | ||||
| #include <stdarg.h> | ||||
| #include <unistd.h> | ||||
| #include <libutil.h> | ||||
|  | ||||
| int | ||||
| flopen(const char *path, int flags, ...) | ||||
| { | ||||
| 	int fd, operation, serrno, trunc; | ||||
| 	struct stat sb, fsb; | ||||
| 	mode_t mode; | ||||
|  | ||||
| #ifdef O_EXLOCK | ||||
| 	flags &= ~O_EXLOCK; | ||||
| #endif | ||||
|  | ||||
| 	mode = 0; | ||||
| 	if (flags & O_CREAT) { | ||||
| 		va_list ap; | ||||
|  | ||||
| 		va_start(ap, flags); | ||||
| 		mode = (mode_t)va_arg(ap, int); /* mode_t promoted to int */ | ||||
| 		va_end(ap); | ||||
| 	} | ||||
|  | ||||
|         operation = LOCK_EX; | ||||
|         if (flags & O_NONBLOCK) | ||||
|                 operation |= LOCK_NB; | ||||
|  | ||||
| 	trunc = (flags & O_TRUNC); | ||||
| 	flags &= ~O_TRUNC; | ||||
|  | ||||
| 	for (;;) { | ||||
| 		if ((fd = open(path, flags, mode)) == -1) | ||||
| 			/* non-existent or no access */ | ||||
| 			return (-1); | ||||
| 		if (flock(fd, operation) == -1) { | ||||
| 			/* unsupported or interrupted */ | ||||
| 			serrno = errno; | ||||
| 			(void)close(fd); | ||||
| 			errno = serrno; | ||||
| 			return (-1); | ||||
| 		} | ||||
| 		if (stat(path, &sb) == -1) { | ||||
| 			/* disappeared from under our feet */ | ||||
| 			(void)close(fd); | ||||
| 			continue; | ||||
| 		} | ||||
| 		if (fstat(fd, &fsb) == -1) { | ||||
| 			/* can't happen [tm] */ | ||||
| 			serrno = errno; | ||||
| 			(void)close(fd); | ||||
| 			errno = serrno; | ||||
| 			return (-1); | ||||
| 		} | ||||
| 		if (sb.st_dev != fsb.st_dev || | ||||
| 		    sb.st_ino != fsb.st_ino) { | ||||
| 			/* changed under our feet */ | ||||
| 			(void)close(fd); | ||||
| 			continue; | ||||
| 		} | ||||
| 		if (trunc && ftruncate(fd, 0) != 0) { | ||||
| 			/* can't happen [tm] */ | ||||
| 			serrno = errno; | ||||
| 			(void)close(fd); | ||||
| 			errno = serrno; | ||||
| 			return (-1); | ||||
| 		} | ||||
| 		return (fd); | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										230
									
								
								src/fparseln.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										230
									
								
								src/fparseln.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,230 @@ | ||||
| /*	$NetBSD: fparseln.c,v 1.10 2009/10/21 01:07:45 snj Exp $	*/ | ||||
|  | ||||
| /* | ||||
|  * Copyright (c) 1997 Christos Zoulas.  All rights reserved. | ||||
|  * | ||||
|  * 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. | ||||
|  * | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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. | ||||
|  */ | ||||
|  | ||||
| #include <sys/cdefs.h> | ||||
| #if defined(LIBC_SCCS) && !defined(lint) | ||||
| __RCSID("$NetBSD: fparseln.c,v 1.10 2009/10/21 01:07:45 snj Exp $"); | ||||
| #endif /* LIBC_SCCS and not lint */ | ||||
|  | ||||
| #include <assert.h> | ||||
| #include <errno.h> | ||||
| #include <stdio.h> | ||||
| #include <string.h> | ||||
| #include <stdlib.h> | ||||
|  | ||||
| #define FLOCKFILE(fp) | ||||
| #define FUNLOCKFILE(fp) | ||||
| #define _DIAGASSERT(t) | ||||
|  | ||||
| static int isescaped(const char *, const char *, int); | ||||
|  | ||||
| /* isescaped(): | ||||
|  *	Return true if the character in *p that belongs to a string | ||||
|  *	that starts in *sp, is escaped by the escape character esc. | ||||
|  */ | ||||
| static int | ||||
| isescaped(const char *sp, const char *p, int esc) | ||||
| { | ||||
| 	const char     *cp; | ||||
| 	size_t		ne; | ||||
|  | ||||
| 	_DIAGASSERT(sp != NULL); | ||||
| 	_DIAGASSERT(p != NULL); | ||||
|  | ||||
| 	/* No escape character */ | ||||
| 	if (esc == '\0') | ||||
| 		return 0; | ||||
|  | ||||
| 	/* Count the number of escape characters that precede ours */ | ||||
| 	for (ne = 0, cp = p; --cp >= sp && *cp == esc; ne++) | ||||
| 		continue; | ||||
|  | ||||
| 	/* Return true if odd number of escape characters */ | ||||
| 	return (ne & 1) != 0; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* fparseln(): | ||||
|  *	Read a line from a file parsing continuations ending in \ | ||||
|  *	and eliminating trailing newlines, or comments starting with | ||||
|  *	the comment char. | ||||
|  */ | ||||
| char * | ||||
| fparseln(FILE *fp, size_t *size, size_t *lineno, const char str[3], int flags) | ||||
| { | ||||
| 	static const char dstr[3] = { '\\', '\\', '#' }; | ||||
|  | ||||
| 	size_t	s, len; | ||||
| 	char   *buf; | ||||
| 	char   *ptr, *cp; | ||||
| 	int	cnt; | ||||
| 	char	esc, con, nl, com; | ||||
|  | ||||
| 	_DIAGASSERT(fp != NULL); | ||||
|  | ||||
| 	len = 0; | ||||
| 	buf = NULL; | ||||
| 	cnt = 1; | ||||
|  | ||||
| 	if (str == NULL) | ||||
| 		str = dstr; | ||||
|  | ||||
| 	esc = str[0]; | ||||
| 	con = str[1]; | ||||
| 	com = str[2]; | ||||
| 	/* | ||||
| 	 * XXX: it would be cool to be able to specify the newline character, | ||||
| 	 * but unfortunately, fgetln does not let us | ||||
| 	 */ | ||||
| 	nl  = '\n'; | ||||
|  | ||||
| 	FLOCKFILE(fp); | ||||
|  | ||||
| 	while (cnt) { | ||||
| 		cnt = 0; | ||||
|  | ||||
| 		if (lineno) | ||||
| 			(*lineno)++; | ||||
|  | ||||
| 		if ((ptr = fgetln(fp, &s)) == NULL) | ||||
| 			break; | ||||
|  | ||||
| 		if (s && com) {		/* Check and eliminate comments */ | ||||
| 			for (cp = ptr; cp < ptr + s; cp++) | ||||
| 				if (*cp == com && !isescaped(ptr, cp, esc)) { | ||||
| 					s = cp - ptr; | ||||
| 					cnt = s == 0 && buf == NULL; | ||||
| 					break; | ||||
| 				} | ||||
| 		} | ||||
|  | ||||
| 		if (s && nl) { 		/* Check and eliminate newlines */ | ||||
| 			cp = &ptr[s - 1]; | ||||
|  | ||||
| 			if (*cp == nl) | ||||
| 				s--;	/* forget newline */ | ||||
| 		} | ||||
|  | ||||
| 		if (s && con) {		/* Check and eliminate continuations */ | ||||
| 			cp = &ptr[s - 1]; | ||||
|  | ||||
| 			if (*cp == con && !isescaped(ptr, cp, esc)) { | ||||
| 				s--;	/* forget continuation char */ | ||||
| 				cnt = 1; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		if (s == 0) { | ||||
| 			/* | ||||
| 			 * nothing to add, skip realloc except in case | ||||
| 			 * we need a minimal buf to return an empty line | ||||
| 			 */ | ||||
| 			if (cnt || buf != NULL) | ||||
| 				continue; | ||||
| 		} | ||||
|  | ||||
| 		if ((cp = realloc(buf, len + s + 1)) == NULL) { | ||||
| 			FUNLOCKFILE(fp); | ||||
| 			free(buf); | ||||
| 			return NULL; | ||||
| 		} | ||||
| 		buf = cp; | ||||
|  | ||||
| 		(void) memcpy(buf + len, ptr, s); | ||||
| 		len += s; | ||||
| 		buf[len] = '\0'; | ||||
| 	} | ||||
|  | ||||
| 	FUNLOCKFILE(fp); | ||||
|  | ||||
| 	if ((flags & FPARSELN_UNESCALL) != 0 && esc && buf != NULL && | ||||
| 	    strchr(buf, esc) != NULL) { | ||||
| 		ptr = cp = buf; | ||||
| 		while (cp[0] != '\0') { | ||||
| 			int skipesc; | ||||
|  | ||||
| 			while (cp[0] != '\0' && cp[0] != esc) | ||||
| 				*ptr++ = *cp++; | ||||
| 			if (cp[0] == '\0' || cp[1] == '\0') | ||||
| 				break; | ||||
|  | ||||
| 			skipesc = 0; | ||||
| 			if (cp[1] == com) | ||||
| 				skipesc += (flags & FPARSELN_UNESCCOMM); | ||||
| 			if (cp[1] == con) | ||||
| 				skipesc += (flags & FPARSELN_UNESCCONT); | ||||
| 			if (cp[1] == esc) | ||||
| 				skipesc += (flags & FPARSELN_UNESCESC); | ||||
| 			if (cp[1] != com && cp[1] != con && cp[1] != esc) | ||||
| 				skipesc = (flags & FPARSELN_UNESCREST); | ||||
|  | ||||
| 			if (skipesc) | ||||
| 				cp++; | ||||
| 			else | ||||
| 				*ptr++ = *cp++; | ||||
| 			*ptr++ = *cp++; | ||||
| 		} | ||||
| 		*ptr = '\0'; | ||||
| 		len = strlen(buf); | ||||
| 	} | ||||
|  | ||||
| 	if (size) | ||||
| 		*size = len; | ||||
| 	return buf; | ||||
| } | ||||
|  | ||||
| #ifdef TEST | ||||
|  | ||||
| int main(int, char **); | ||||
|  | ||||
| int | ||||
| main(int argc, char **argv) | ||||
| { | ||||
| 	char   *ptr; | ||||
| 	size_t	size, line; | ||||
|  | ||||
| 	line = 0; | ||||
| 	while ((ptr = fparseln(stdin, &size, &line, NULL, | ||||
| 	    FPARSELN_UNESCALL)) != NULL) | ||||
| 		printf("line %d (%d) |%s|\n", line, size, ptr); | ||||
| 	return 0; | ||||
| } | ||||
|  | ||||
| /* | ||||
|  | ||||
| # This is a test | ||||
| line 1 | ||||
| line 2 \ | ||||
| line 3 # Comment | ||||
| line 4 \# Not comment \\\\ | ||||
|  | ||||
| # And a comment \ | ||||
| line 5 \\\ | ||||
| line 6 | ||||
|  | ||||
| */ | ||||
|  | ||||
| #endif /* TEST */ | ||||
							
								
								
									
										66
									
								
								src/fpurge.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								src/fpurge.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,66 @@ | ||||
| /* | ||||
|  * Copyright © 2011 Guillem Jover <guillem@hadrons.org> | ||||
|  * | ||||
|  * 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. | ||||
|  */ | ||||
|  | ||||
| #include <errno.h> | ||||
| #include <stdio.h> | ||||
| #include <stdio_ext.h> | ||||
|  | ||||
| #ifdef HAVE___FPURGE | ||||
| int | ||||
| fpurge(FILE *fp) | ||||
| { | ||||
| 	if (fp == NULL || fileno(fp) < 0) { | ||||
| 		errno = EBADF; | ||||
| 		return EOF; | ||||
| 	} | ||||
|  | ||||
| 	__fpurge(fp); | ||||
|  | ||||
| 	return 0; | ||||
| } | ||||
| #else | ||||
| #error "Function fpurge() needs to be ported." | ||||
| #endif | ||||
|  | ||||
| #ifdef TEST | ||||
| int | ||||
| main() | ||||
| { | ||||
| 	static FILE fp_bad; | ||||
| 	FILE *fp; | ||||
|  | ||||
| 	if (fpurge(&fp_bad) == 0) | ||||
| 		return 1; | ||||
|  | ||||
| 	fp = fopen("/dev/zero", "r"); | ||||
| 	if (fpurge(fp) < 0) | ||||
| 		return 1; | ||||
|  | ||||
| 	fclose(fp); | ||||
|  | ||||
| 	return 0; | ||||
| } | ||||
| #endif | ||||
							
								
								
									
										134
									
								
								src/getpeereid.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										134
									
								
								src/getpeereid.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,134 @@ | ||||
| /* | ||||
|  * Copyright © 2010 Guillem Jover <guillem@hadrons.org> | ||||
|  * | ||||
|  * 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. | ||||
|  */ | ||||
|  | ||||
| #include <sys/cdefs.h> | ||||
|  | ||||
| #include <sys/param.h> | ||||
| #include <sys/types.h> | ||||
| #include <sys/socket.h> | ||||
| #include <sys/un.h> | ||||
|  | ||||
| #include <errno.h> | ||||
| #include <unistd.h> | ||||
|  | ||||
| #if defined(SO_PEERCRED) | ||||
| /* Linux and OpenBSD */ | ||||
| int | ||||
| getpeereid(int s, uid_t *euid, gid_t *egid) | ||||
| { | ||||
| /* XXX: This should be autodetected at build time instead. */ | ||||
| #if defined(__linux__) | ||||
| 	struct ucred cred; | ||||
| #elif defined(__OpenBSD__) | ||||
| 	struct sockpeercred cred; | ||||
| #endif | ||||
| 	socklen_t credlen = sizeof(cred); | ||||
| 	int ret; | ||||
|  | ||||
| 	ret = getsockopt(s, SOL_SOCKET, SO_PEERCRED, &cred, &credlen); | ||||
| 	if (ret != 0) | ||||
| 		return ret; | ||||
|  | ||||
| 	*euid = cred.uid; | ||||
| 	*egid = cred.gid; | ||||
|  | ||||
| 	return 0; | ||||
| } | ||||
| #elif defined(LOCAL_PEERCRED) | ||||
| /* FreeBSD */ | ||||
| #include <sys/ucred.h> | ||||
|  | ||||
| int | ||||
| getpeereid(int s, uid_t *euid, gid_t *egid) | ||||
| { | ||||
| 	struct xucred cred; | ||||
| 	socklen_t credlen = sizeof(cred); | ||||
| 	int ret; | ||||
|  | ||||
| 	ret = getsockopt(s, 0, LOCAL_PEERCRED, &cred, &credlen); | ||||
| 	if (ret != 0) | ||||
| 		return ret; | ||||
| 	if (cred.cr_version != XUCRED_VERSION) | ||||
| 		return EINVAL; | ||||
|  | ||||
| 	*euid = cred.cr_uid; | ||||
| 	*egid = cred.cr_gid; | ||||
|  | ||||
| 	return 0; | ||||
| } | ||||
| #elif defined(LOCAL_PEEREID) | ||||
| /* NetBSD */ | ||||
| int | ||||
| getpeereid(int s, uid_t *euid, gid_t *egid) | ||||
| { | ||||
| 	struct unpcbid cred; | ||||
| 	socklen_t credlen = sizeof(cred); | ||||
| 	int ret; | ||||
|  | ||||
| 	ret = getsockopt(s, 0, LOCAL_PEEREID, &cred, &credlen); | ||||
| 	if (ret != 0) | ||||
| 		return ret; | ||||
|  | ||||
| 	*euid = cred.unp_euid; | ||||
| 	*egid = cred.unp_egid; | ||||
|  | ||||
| 	return 0; | ||||
| } | ||||
| #elif defined(__sun) | ||||
| /* Solaris */ | ||||
| #include <alloca.h> | ||||
| #include <ucred.h> | ||||
|  | ||||
| int | ||||
| getpeereid(int s, uid_t *euid, gid_t *egid) | ||||
| { | ||||
| 	ucred_t *cred = alloca(ucred_size()); | ||||
| 	int ret; | ||||
|  | ||||
| 	ret = getpeerucred(s, &cred); | ||||
| 	if (ret != 0) | ||||
| 		return ret; | ||||
|  | ||||
| 	*euid = ucred_geteuid(cred); | ||||
| 	if (*euid < 0) | ||||
| 		return -1; | ||||
| 	*egid = ucred_getegid(cred); | ||||
| 	if (*egid < 0) | ||||
| 		return -1; | ||||
|  | ||||
| 	return 0; | ||||
| } | ||||
| #else | ||||
| #warning "This platform needs an implementation of getpeereid()" | ||||
| int | ||||
| getpeereid(int s, uid_t *euid, gid_t *egid) | ||||
| { | ||||
| 	*euid = geteuid(); | ||||
| 	*egid = getegid(); | ||||
|  | ||||
| 	return 0; | ||||
| } | ||||
| #endif | ||||
| @@ -19,7 +19,7 @@ | ||||
|  | ||||
| #include <sys/types.h> | ||||
| #include <string.h> | ||||
| #include <bsd/md5.h> | ||||
| #include <md5.h> | ||||
|  | ||||
| #define PUT_64BIT_LE(cp, value) do {					\ | ||||
| 	(cp)[7] = (value) >> 56;					\ | ||||
|   | ||||
| @@ -86,7 +86,7 @@ | ||||
|  * Select the top of the heap and 'heapify'.  Since by far the most expensive | ||||
|  * action is the call to the compar function, a considerable optimization | ||||
|  * in the average case can be achieved due to the fact that k, the displaced | ||||
|  * elememt, is ususally quite small, so it would be preferable to first | ||||
|  * elememt, is usually quite small, so it would be preferable to first | ||||
|  * heapify, always maintaining the invariant that the larger child is copied | ||||
|  * over its parent's record. | ||||
|  * | ||||
| @@ -135,7 +135,7 @@ heapsort(vbase, nmemb, size, compar) | ||||
| 	size_t nmemb, size; | ||||
| 	int (*compar)(const void *, const void *); | ||||
| { | ||||
| 	int cnt, i, j, l; | ||||
| 	size_t cnt, i, j, l; | ||||
| 	char tmp, *tmp1, *tmp2; | ||||
| 	char *base, *k, *p, *t; | ||||
|  | ||||
|   | ||||
							
								
								
									
										11
									
								
								src/libbsd-overlay.pc.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								src/libbsd-overlay.pc.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | ||||
| prefix=@prefix@ | ||||
| exec_prefix=@exec_prefix@ | ||||
| libdir=@libdir@ | ||||
| includedir=@includedir@ | ||||
|  | ||||
| Name: libbsd | ||||
| Description: Utility functions from BSD systems (overlay) | ||||
| Version: @VERSION@ | ||||
| URL: http://libbsd.freedesktop.org/ | ||||
| Libs: -L${libdir} -lbsd | ||||
| Cflags: -isystem ${includedir}/bsd -DLIBBSD_OVERLAY | ||||
							
								
								
									
										107
									
								
								src/libbsd.map
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										107
									
								
								src/libbsd.map
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,107 @@ | ||||
| LIBBSD_0.0 { | ||||
|   global: | ||||
|     arc4random; | ||||
|     arc4random_stir; | ||||
|     arc4random_addrandom; | ||||
|  | ||||
|     bsd_getopt; | ||||
|     optreset; | ||||
|  | ||||
|     errc; | ||||
|     warnc; | ||||
|     verrc; | ||||
|     vwarnc; | ||||
|  | ||||
|     fgetln; | ||||
|     fmtcheck; | ||||
|     heapsort; | ||||
|     humanize_number; | ||||
|  | ||||
|     inet_net_pton; /* XXX: Already provided by glibc, remove. */ | ||||
|  | ||||
|     getprogname; | ||||
|     setprogname; | ||||
|  | ||||
|     strlcpy; | ||||
|     strlcat; | ||||
|  | ||||
|     setmode; | ||||
|     getmode; | ||||
|  | ||||
|     vis; | ||||
|     strvis; | ||||
|     strvisx; | ||||
|     unvis; | ||||
|     strunvis; | ||||
|     strunvisx; | ||||
|  | ||||
|     MD5Init; | ||||
|     MD5Update; | ||||
|     MD5Pad; | ||||
|     MD5Final; | ||||
|     MD5Transform; | ||||
|     MD5End; | ||||
|     MD5File; | ||||
|     MD5FileChunk; | ||||
|     MD5Data; | ||||
|  | ||||
|   local: | ||||
|     *; | ||||
| }; | ||||
|  | ||||
| LIBBSD_0.1 { | ||||
|     strmode; | ||||
|  | ||||
|     __fdnlist; /* Private symbol, but libkvm uses it. */ | ||||
|     nlist; | ||||
| } LIBBSD_0.0; | ||||
|  | ||||
| LIBBSD_0.2 { | ||||
|     strtonum; | ||||
|  | ||||
|     strnvis; | ||||
|     strnunvis; | ||||
|  | ||||
|     dehumanize_number; | ||||
|  | ||||
|     readpassphrase; | ||||
|  | ||||
|     flopen; | ||||
|  | ||||
|     pidfile_open; | ||||
|     pidfile_write; | ||||
|     pidfile_close; | ||||
|     pidfile_remove; | ||||
|  | ||||
|     arc4random_buf; | ||||
|     arc4random_uniform; | ||||
| } LIBBSD_0.1; | ||||
|  | ||||
| LIBBSD_0.3 { | ||||
|     reallocf; | ||||
|     getpeereid; | ||||
|  | ||||
|     mergesort; | ||||
|     radixsort; | ||||
|     sradixsort; | ||||
|  | ||||
|     fpurge; | ||||
| } LIBBSD_0.2; | ||||
|  | ||||
| LIBBSD_0.4 { | ||||
|     closefrom; | ||||
|     expand_number; | ||||
| } LIBBSD_0.3; | ||||
|  | ||||
| LIBBSD_0.5 { | ||||
|     fgetwln; | ||||
|     fparseln; | ||||
|  | ||||
|     /* Introduced in 0.2 as a stub, implemented in 0.5. */ | ||||
|     setproctitle; | ||||
|  | ||||
|     strnstr; | ||||
|  | ||||
|     wcslcat; | ||||
|     wcslcpy; | ||||
| } LIBBSD_0.4; | ||||
| @@ -1,5 +1,5 @@ | ||||
| /* | ||||
|  * Copyright © 2009 Guillem Jover | ||||
|  * Copyright © 2009, 2012 Guillem Jover <guillem@hadrons.org> | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
|  * modification, are permitted provided that the following conditions | ||||
| @@ -46,7 +46,11 @@ | ||||
| #elif defined(__amd64__) | ||||
|  | ||||
| #define ELF_TARG_MACH	EM_X86_64 | ||||
| #if defined(__ILP32__) | ||||
| #define ELF_TARG_CLASS	ELFCLASS32 | ||||
| #else | ||||
| #define ELF_TARG_CLASS	ELFCLASS64 | ||||
| #endif | ||||
| #define ELF_TARG_DATA	ELFDATA2LSB | ||||
|  | ||||
| #elif defined(__arm__) | ||||
| @@ -59,6 +63,16 @@ | ||||
| #define ELF_TARG_DATA	ELFDATA2LSB | ||||
| #endif | ||||
|  | ||||
| #elif defined(__aarch64__) | ||||
|  | ||||
| #define ELF_TARG_MACH	EM_AARCH64 | ||||
| #define ELF_TARG_CLASS	ELFCLASS64 | ||||
| #if defined(__AARCH64EB__) | ||||
| #define ELF_TARG_DATA	ELFDATA2MSB | ||||
| #else | ||||
| #define ELF_TARG_DATA	ELFDATA2LSB | ||||
| #endif | ||||
|  | ||||
| #elif defined(__avr32__) | ||||
|  | ||||
| #ifndef EM_AVR32 | ||||
| @@ -97,9 +111,9 @@ | ||||
| #define ELF_TARG_MACH	EM_M32R | ||||
| #define ELF_TARG_CLASS	ELFCLASS32 | ||||
| #if defined(__LITTLE_ENDIAN__) | ||||
| #define ELF_DATA	ELFDATA2LSB | ||||
| #define ELF_TARG_DATA	ELFDATA2LSB | ||||
| #elif defined(__BIG_ENDIAN__) | ||||
| #define ELF_DATA	ELFDATA2MSB | ||||
| #define ELF_TARG_DATA	ELFDATA2MSB | ||||
| #else | ||||
| #error Unknown M32R endianness | ||||
| #endif | ||||
| @@ -194,4 +208,3 @@ | ||||
| #endif | ||||
|  | ||||
| #endif | ||||
|  | ||||
|   | ||||
							
								
								
									
										351
									
								
								src/merge.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										351
									
								
								src/merge.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,351 @@ | ||||
| /*- | ||||
|  * Copyright (c) 1992, 1993 | ||||
|  *	The Regents of the University of California.  All rights reserved. | ||||
|  * | ||||
|  * This code is derived from software contributed to Berkeley by | ||||
|  * Peter McIlroy. | ||||
|  * | ||||
|  * 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. | ||||
|  * 4. Neither the name of the University nor the names of its contributors | ||||
|  *    may be used to endorse or promote products derived from this software | ||||
|  *    without specific prior written permission. | ||||
|  * | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``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 REGENTS OR CONTRIBUTORS 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. | ||||
|  */ | ||||
|  | ||||
| #if defined(LIBC_SCCS) && !defined(lint) | ||||
| static char sccsid[] = "@(#)merge.c	8.2 (Berkeley) 2/14/94"; | ||||
| #endif /* LIBC_SCCS and not lint */ | ||||
| #include <sys/cdefs.h> | ||||
| __FBSDID("$FreeBSD$"); | ||||
|  | ||||
| /* | ||||
|  * Hybrid exponential search/linear search merge sort with hybrid | ||||
|  * natural/pairwise first pass.  Requires about .3% more comparisons | ||||
|  * for random data than LSMS with pairwise first pass alone. | ||||
|  * It works for objects as small as two bytes. | ||||
|  */ | ||||
|  | ||||
| #define NATURAL | ||||
| #define THRESHOLD 16	/* Best choice for natural merge cut-off. */ | ||||
|  | ||||
| /* #define NATURAL to get hybrid natural merge. | ||||
|  * (The default is pairwise merging.) | ||||
|  */ | ||||
|  | ||||
| #include <sys/types.h> | ||||
|  | ||||
| #include <errno.h> | ||||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
|  | ||||
| static void setup(u_char *, u_char *, size_t, size_t, | ||||
|     int (*)(const void *, const void *)); | ||||
| static void insertionsort(u_char *, size_t, size_t, | ||||
|     int (*)(const void *, const void *)); | ||||
|  | ||||
| #define ISIZE sizeof(int) | ||||
| #define PSIZE sizeof(u_char *) | ||||
| #define ICOPY_LIST(src, dst, last)				\ | ||||
| 	do							\ | ||||
| 	*(int*)dst = *(int*)src, src += ISIZE, dst += ISIZE;	\ | ||||
| 	while(src < last) | ||||
| #define ICOPY_ELT(src, dst, i)					\ | ||||
| 	do							\ | ||||
| 	*(int*) dst = *(int*) src, src += ISIZE, dst += ISIZE;	\ | ||||
| 	while (i -= ISIZE) | ||||
|  | ||||
| #define CCOPY_LIST(src, dst, last)		\ | ||||
| 	do					\ | ||||
| 		*dst++ = *src++;		\ | ||||
| 	while (src < last) | ||||
| #define CCOPY_ELT(src, dst, i)			\ | ||||
| 	do					\ | ||||
| 		*dst++ = *src++;		\ | ||||
| 	while (i -= 1) | ||||
|  | ||||
| /* | ||||
|  * Find the next possible pointer head.  (Trickery for forcing an array | ||||
|  * to do double duty as a linked list when objects do not align with word | ||||
|  * boundaries. | ||||
|  */ | ||||
| /* Assumption: PSIZE is a power of 2. */ | ||||
| #define EVAL(p) (u_char **)						\ | ||||
| 	((u_char *)0 +							\ | ||||
| 	    (((u_char *)p + PSIZE - 1 - (u_char *) 0) & ~(PSIZE - 1))) | ||||
|  | ||||
| /* | ||||
|  * Arguments are as for qsort. | ||||
|  */ | ||||
| int | ||||
| mergesort(base, nmemb, size, cmp) | ||||
| 	void *base; | ||||
| 	size_t nmemb; | ||||
| 	size_t size; | ||||
| 	int (*cmp)(const void *, const void *); | ||||
| { | ||||
| 	size_t i; | ||||
| 	int sense; | ||||
| 	int big, iflag; | ||||
| 	u_char *f1, *f2, *t, *b, *tp2, *q, *l1, *l2; | ||||
| 	u_char *list2, *list1, *p2, *p, *last, **p1; | ||||
|  | ||||
| 	if (size < PSIZE / 2) {		/* Pointers must fit into 2 * size. */ | ||||
| 		errno = EINVAL; | ||||
| 		return (-1); | ||||
| 	} | ||||
|  | ||||
| 	if (nmemb == 0) | ||||
| 		return (0); | ||||
|  | ||||
| 	/* | ||||
| 	 * XXX | ||||
| 	 * Stupid subtraction for the Cray. | ||||
| 	 */ | ||||
| 	iflag = 0; | ||||
| 	if (!(size % ISIZE) && !(((char *)base - (char *)0) % ISIZE)) | ||||
| 		iflag = 1; | ||||
|  | ||||
| 	if ((list2 = malloc(nmemb * size + PSIZE)) == NULL) | ||||
| 		return (-1); | ||||
|  | ||||
| 	list1 = base; | ||||
| 	setup(list1, list2, nmemb, size, cmp); | ||||
| 	last = list2 + nmemb * size; | ||||
| 	i = big = 0; | ||||
| 	while (*EVAL(list2) != last) { | ||||
| 	    l2 = list1; | ||||
| 	    p1 = EVAL(list1); | ||||
| 	    for (tp2 = p2 = list2; p2 != last; p1 = EVAL(l2)) { | ||||
| 	    	p2 = *EVAL(p2); | ||||
| 	    	f1 = l2; | ||||
| 	    	f2 = l1 = list1 + (p2 - list2); | ||||
| 	    	if (p2 != last) | ||||
| 	    		p2 = *EVAL(p2); | ||||
| 	    	l2 = list1 + (p2 - list2); | ||||
| 	    	while (f1 < l1 && f2 < l2) { | ||||
| 	    		if ((*cmp)(f1, f2) <= 0) { | ||||
| 	    			q = f2; | ||||
| 	    			b = f1, t = l1; | ||||
| 	    			sense = -1; | ||||
| 	    		} else { | ||||
| 	    			q = f1; | ||||
| 	    			b = f2, t = l2; | ||||
| 	    			sense = 0; | ||||
| 	    		} | ||||
| 	    		if (!big) {	/* here i = 0 */ | ||||
| 				while ((b += size) < t && cmp(q, b) >sense) | ||||
| 	    				if (++i == 6) { | ||||
| 	    					big = 1; | ||||
| 	    					goto EXPONENTIAL; | ||||
| 	    				} | ||||
| 	    		} else { | ||||
| EXPONENTIAL:	    		for (i = size; ; i <<= 1) | ||||
| 	    				if ((p = (b + i)) >= t) { | ||||
| 	    					if ((p = t - size) > b && | ||||
| 						    (*cmp)(q, p) <= sense) | ||||
| 	    						t = p; | ||||
| 	    					else | ||||
| 	    						b = p; | ||||
| 	    					break; | ||||
| 	    				} else if ((*cmp)(q, p) <= sense) { | ||||
| 	    					t = p; | ||||
| 	    					if (i == size) | ||||
| 	    						big = 0; | ||||
| 	    					goto FASTCASE; | ||||
| 	    				} else | ||||
| 	    					b = p; | ||||
| 				while (t > b+size) { | ||||
| 	    				i = (((t - b) / size) >> 1) * size; | ||||
| 	    				if ((*cmp)(q, p = b + i) <= sense) | ||||
| 	    					t = p; | ||||
| 	    				else | ||||
| 	    					b = p; | ||||
| 	    			} | ||||
| 	    			goto COPY; | ||||
| FASTCASE:	    		while (i > size) | ||||
| 	    				if ((*cmp)(q, | ||||
| 	    					p = b + (i >>= 1)) <= sense) | ||||
| 	    					t = p; | ||||
| 	    				else | ||||
| 	    					b = p; | ||||
| COPY:	    			b = t; | ||||
| 	    		} | ||||
| 	    		i = size; | ||||
| 	    		if (q == f1) { | ||||
| 	    			if (iflag) { | ||||
| 	    				ICOPY_LIST(f2, tp2, b); | ||||
| 	    				ICOPY_ELT(f1, tp2, i); | ||||
| 	    			} else { | ||||
| 	    				CCOPY_LIST(f2, tp2, b); | ||||
| 	    				CCOPY_ELT(f1, tp2, i); | ||||
| 	    			} | ||||
| 	    		} else { | ||||
| 	    			if (iflag) { | ||||
| 	    				ICOPY_LIST(f1, tp2, b); | ||||
| 	    				ICOPY_ELT(f2, tp2, i); | ||||
| 	    			} else { | ||||
| 	    				CCOPY_LIST(f1, tp2, b); | ||||
| 	    				CCOPY_ELT(f2, tp2, i); | ||||
| 	    			} | ||||
| 	    		} | ||||
| 	    	} | ||||
| 	    	if (f2 < l2) { | ||||
| 	    		if (iflag) | ||||
| 	    			ICOPY_LIST(f2, tp2, l2); | ||||
| 	    		else | ||||
| 	    			CCOPY_LIST(f2, tp2, l2); | ||||
| 	    	} else if (f1 < l1) { | ||||
| 	    		if (iflag) | ||||
| 	    			ICOPY_LIST(f1, tp2, l1); | ||||
| 	    		else | ||||
| 	    			CCOPY_LIST(f1, tp2, l1); | ||||
| 	    	} | ||||
| 	    	*p1 = l2; | ||||
| 	    } | ||||
| 	    tp2 = list1;	/* swap list1, list2 */ | ||||
| 	    list1 = list2; | ||||
| 	    list2 = tp2; | ||||
| 	    last = list2 + nmemb*size; | ||||
| 	} | ||||
| 	if (base == list2) { | ||||
| 		memmove(list2, list1, nmemb*size); | ||||
| 		list2 = list1; | ||||
| 	} | ||||
| 	free(list2); | ||||
| 	return (0); | ||||
| } | ||||
|  | ||||
| #define	swap(a, b) {					\ | ||||
| 		s = b;					\ | ||||
| 		i = size;				\ | ||||
| 		do {					\ | ||||
| 			tmp = *a; *a++ = *s; *s++ = tmp; \ | ||||
| 		} while (--i);				\ | ||||
| 		a -= size;				\ | ||||
| 	} | ||||
| #define reverse(bot, top) {				\ | ||||
| 	s = top;					\ | ||||
| 	do {						\ | ||||
| 		i = size;				\ | ||||
| 		do {					\ | ||||
| 			tmp = *bot; *bot++ = *s; *s++ = tmp; \ | ||||
| 		} while (--i);				\ | ||||
| 		s -= size2;				\ | ||||
| 	} while(bot < s);				\ | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * Optional hybrid natural/pairwise first pass.  Eats up list1 in runs of | ||||
|  * increasing order, list2 in a corresponding linked list.  Checks for runs | ||||
|  * when THRESHOLD/2 pairs compare with same sense.  (Only used when NATURAL | ||||
|  * is defined.  Otherwise simple pairwise merging is used.) | ||||
|  */ | ||||
| void | ||||
| setup(list1, list2, n, size, cmp) | ||||
| 	size_t n, size; | ||||
| 	int (*cmp)(const void *, const void *); | ||||
| 	u_char *list1, *list2; | ||||
| { | ||||
| 	int i, length, size2, tmp, sense; | ||||
| 	u_char *f1, *f2, *s, *l2, *last, *p2; | ||||
|  | ||||
| 	size2 = size*2; | ||||
| 	if (n <= 5) { | ||||
| 		insertionsort(list1, n, size, cmp); | ||||
| 		*EVAL(list2) = (u_char*) list2 + n*size; | ||||
| 		return; | ||||
| 	} | ||||
| 	/* | ||||
| 	 * Avoid running pointers out of bounds; limit n to evens | ||||
| 	 * for simplicity. | ||||
| 	 */ | ||||
| 	i = 4 + (n & 1); | ||||
| 	insertionsort(list1 + (n - i) * size, i, size, cmp); | ||||
| 	last = list1 + size * (n - i); | ||||
| 	*EVAL(list2 + (last - list1)) = list2 + n * size; | ||||
|  | ||||
| #ifdef NATURAL | ||||
| 	p2 = list2; | ||||
| 	f1 = list1; | ||||
| 	sense = (cmp(f1, f1 + size) > 0); | ||||
| 	for (; f1 < last; sense = !sense) { | ||||
| 		length = 2; | ||||
| 					/* Find pairs with same sense. */ | ||||
| 		for (f2 = f1 + size2; f2 < last; f2 += size2) { | ||||
| 			if ((cmp(f2, f2+ size) > 0) != sense) | ||||
| 				break; | ||||
| 			length += 2; | ||||
| 		} | ||||
| 		if (length < THRESHOLD) {		/* Pairwise merge */ | ||||
| 			do { | ||||
| 				p2 = *EVAL(p2) = f1 + size2 - list1 + list2; | ||||
| 				if (sense > 0) | ||||
| 					swap (f1, f1 + size); | ||||
| 			} while ((f1 += size2) < f2); | ||||
| 		} else {				/* Natural merge */ | ||||
| 			l2 = f2; | ||||
| 			for (f2 = f1 + size2; f2 < l2; f2 += size2) { | ||||
| 				if ((cmp(f2-size, f2) > 0) != sense) { | ||||
| 					p2 = *EVAL(p2) = f2 - list1 + list2; | ||||
| 					if (sense > 0) | ||||
| 						reverse(f1, f2-size); | ||||
| 					f1 = f2; | ||||
| 				} | ||||
| 			} | ||||
| 			if (sense > 0) | ||||
| 				reverse (f1, f2-size); | ||||
| 			f1 = f2; | ||||
| 			if (f2 < last || cmp(f2 - size, f2) > 0) | ||||
| 				p2 = *EVAL(p2) = f2 - list1 + list2; | ||||
| 			else | ||||
| 				p2 = *EVAL(p2) = list2 + n*size; | ||||
| 		} | ||||
| 	} | ||||
| #else		/* pairwise merge only. */ | ||||
| 	for (f1 = list1, p2 = list2; f1 < last; f1 += size2) { | ||||
| 		p2 = *EVAL(p2) = p2 + size2; | ||||
| 		if (cmp (f1, f1 + size) > 0) | ||||
| 			swap(f1, f1 + size); | ||||
| 	} | ||||
| #endif /* NATURAL */ | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * This is to avoid out-of-bounds addresses in sorting the | ||||
|  * last 4 elements. | ||||
|  */ | ||||
| static void | ||||
| insertionsort(a, n, size, cmp) | ||||
| 	u_char *a; | ||||
| 	size_t n, size; | ||||
| 	int (*cmp)(const void *, const void *); | ||||
| { | ||||
| 	u_char *ai, *s, *t, *u, tmp; | ||||
| 	int i; | ||||
|  | ||||
| 	for (ai = a+size; --n >= 1; ai += size) | ||||
| 		for (t = ai; t > a; t -= size) { | ||||
| 			u = t - size; | ||||
| 			if (cmp(u, t) <= 0) | ||||
| 				break; | ||||
| 			swap(u, t); | ||||
| 		} | ||||
| } | ||||
| @@ -100,7 +100,8 @@ __fdnlist(fd, list) | ||||
| 	int fd; | ||||
| 	struct nlist *list; | ||||
| { | ||||
| 	int n = -1, i; | ||||
| 	size_t i; | ||||
| 	int n = -1; | ||||
|  | ||||
| 	for (i = 0; i < sizeof(nlist_fn) / sizeof(nlist_fn[0]); i++) { | ||||
| 		n = (nlist_fn[i].fn)(fd, list); | ||||
| @@ -138,7 +139,7 @@ __aout_fdnlist(fd, list) | ||||
|  | ||||
| 	/* | ||||
| 	 * Map the whole a.out file into our address space. | ||||
| 	 * We then find the string table withing this area. | ||||
| 	 * We then find the string table within this area. | ||||
| 	 * We do not just mmap the string table, as it probably | ||||
| 	 * does not start at a page boundary - we save ourselves a | ||||
| 	 * lot of nastiness by mmapping the whole file. | ||||
| @@ -227,14 +228,14 @@ __elf_is_okay__(ehdr) | ||||
| 	 * We need to check magic, class size, endianess, | ||||
| 	 * and version before we look at the rest of the | ||||
| 	 * Elf_Ehdr structure.  These few elements are | ||||
| 	 * represented in a machine independant fashion. | ||||
| 	 * represented in a machine independent fashion. | ||||
| 	 */ | ||||
| 	if (IS_ELF(*ehdr) && | ||||
| 	    ehdr->e_ident[EI_CLASS] == ELF_TARG_CLASS && | ||||
| 	    ehdr->e_ident[EI_DATA] == ELF_TARG_DATA && | ||||
| 	    ehdr->e_ident[EI_VERSION] == ELF_TARG_VER) { | ||||
|  | ||||
| 		/* Now check the machine dependant header */ | ||||
| 		/* Now check the machine dependent header */ | ||||
| 		if (ehdr->e_machine == ELF_TARG_MACH && | ||||
| 		    ehdr->e_version == ELF_TARG_VER) | ||||
| 			retval = 1; | ||||
|   | ||||
							
								
								
									
										255
									
								
								src/pidfile.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										255
									
								
								src/pidfile.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,255 @@ | ||||
| /*- | ||||
|  * Copyright (c) 2005 Pawel Jakub Dawidek <pjd@FreeBSD.org> | ||||
|  * All rights reserved. | ||||
|  * | ||||
|  * 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. | ||||
|  *  | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE AUTHORS AND CONTRIBUTORS ``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 AUTHORS OR CONTRIBUTORS 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. | ||||
|  */ | ||||
|  | ||||
| #include <sys/cdefs.h> | ||||
| __FBSDID("$FreeBSD$"); | ||||
|  | ||||
| #include <sys/param.h> | ||||
| #include <sys/file.h> | ||||
| #include <sys/stat.h> | ||||
|  | ||||
| #include <stdio.h> | ||||
| #include <stdlib.h> | ||||
| #include <unistd.h> | ||||
| #include <fcntl.h> | ||||
| #include <string.h> | ||||
| #include <time.h> | ||||
| #include <err.h> | ||||
| #include <errno.h> | ||||
| #include <libutil.h> | ||||
|  | ||||
| static int _pidfile_remove(struct pidfh *pfh, int freeit); | ||||
|  | ||||
| static int | ||||
| pidfile_verify(struct pidfh *pfh) | ||||
| { | ||||
| 	struct stat sb; | ||||
|  | ||||
| 	if (pfh == NULL || pfh->pf_fd == -1) | ||||
| 		return (EINVAL); | ||||
| 	/* | ||||
| 	 * Check remembered descriptor. | ||||
| 	 */ | ||||
| 	if (fstat(pfh->pf_fd, &sb) == -1) | ||||
| 		return (errno); | ||||
| 	if (sb.st_dev != pfh->pf_dev || sb.st_ino != pfh->pf_ino) | ||||
| 		return (EINVAL); | ||||
| 	return (0); | ||||
| } | ||||
|  | ||||
| static int | ||||
| pidfile_read(const char *path, pid_t *pidptr) | ||||
| { | ||||
| 	char buf[16], *endptr; | ||||
| 	int error, fd, i; | ||||
|  | ||||
| 	fd = open(path, O_RDONLY); | ||||
| 	if (fd == -1) | ||||
| 		return (errno); | ||||
|  | ||||
| 	i = read(fd, buf, sizeof(buf) - 1); | ||||
| 	error = errno;	/* Remember errno in case close() wants to change it. */ | ||||
| 	close(fd); | ||||
| 	if (i == -1) | ||||
| 		return (error); | ||||
| 	else if (i == 0) | ||||
| 		return (EAGAIN); | ||||
| 	buf[i] = '\0'; | ||||
|  | ||||
| 	*pidptr = strtol(buf, &endptr, 10); | ||||
| 	if (endptr != &buf[i]) | ||||
| 		return (EINVAL); | ||||
|  | ||||
| 	return (0); | ||||
| } | ||||
|  | ||||
| struct pidfh * | ||||
| pidfile_open(const char *path, mode_t mode, pid_t *pidptr) | ||||
| { | ||||
| 	struct pidfh *pfh; | ||||
| 	struct stat sb; | ||||
| 	int error, fd, len, count; | ||||
| 	struct timespec rqtp; | ||||
|  | ||||
| 	pfh = malloc(sizeof(*pfh)); | ||||
| 	if (pfh == NULL) | ||||
| 		return (NULL); | ||||
|  | ||||
| 	if (path == NULL) { | ||||
| 		len = asprintf(&pfh->pf_path, "/var/run/%s.pid", getprogname()); | ||||
| 		if (len < 0) { | ||||
| 			free(pfh); | ||||
| 			return (NULL); | ||||
| 		} | ||||
| 	} else | ||||
| 		pfh->pf_path = strdup(path); | ||||
|  | ||||
| 	/* | ||||
| 	 * Open the PID file and obtain exclusive lock. | ||||
| 	 * We truncate PID file here only to remove old PID immediately, | ||||
| 	 * PID file will be truncated again in pidfile_write(), so | ||||
| 	 * pidfile_write() can be called multiple times. | ||||
| 	 */ | ||||
| 	fd = flopen(pfh->pf_path, | ||||
| 	    O_WRONLY | O_CREAT | O_TRUNC | O_NONBLOCK, mode); | ||||
| 	if (fd == -1) { | ||||
| 		count = 0; | ||||
| 		rqtp.tv_sec = 0; | ||||
| 		rqtp.tv_nsec = 5000000; | ||||
| 		if (errno == EWOULDBLOCK && pidptr != NULL) { | ||||
| 		again: | ||||
| 			errno = pidfile_read(pfh->pf_path, pidptr); | ||||
| 			if (errno == 0) | ||||
| 				errno = EEXIST; | ||||
| 			else if (errno == EAGAIN) { | ||||
| 				if (++count <= 3) { | ||||
| 					nanosleep(&rqtp, 0); | ||||
| 					goto again; | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 		free(pfh->pf_path); | ||||
| 		free(pfh); | ||||
| 		return (NULL); | ||||
| 	} | ||||
| 	/* | ||||
| 	 * Remember file information, so in pidfile_write() we are sure we write | ||||
| 	 * to the proper descriptor. | ||||
| 	 */ | ||||
| 	if (fstat(fd, &sb) == -1) { | ||||
| 		error = errno; | ||||
| 		unlink(pfh->pf_path); | ||||
| 		free(pfh->pf_path); | ||||
| 		close(fd); | ||||
| 		free(pfh); | ||||
| 		errno = error; | ||||
| 		return (NULL); | ||||
| 	} | ||||
|  | ||||
| 	pfh->pf_fd = fd; | ||||
| 	pfh->pf_dev = sb.st_dev; | ||||
| 	pfh->pf_ino = sb.st_ino; | ||||
|  | ||||
| 	return (pfh); | ||||
| } | ||||
|  | ||||
| int | ||||
| pidfile_write(struct pidfh *pfh) | ||||
| { | ||||
| 	char pidstr[16]; | ||||
| 	int error, fd; | ||||
|  | ||||
| 	/* | ||||
| 	 * Check remembered descriptor, so we don't overwrite some other | ||||
| 	 * file if pidfile was closed and descriptor reused. | ||||
| 	 */ | ||||
| 	errno = pidfile_verify(pfh); | ||||
| 	if (errno != 0) { | ||||
| 		/* | ||||
| 		 * Don't close descriptor, because we are not sure if it's ours. | ||||
| 		 */ | ||||
| 		return (-1); | ||||
| 	} | ||||
| 	fd = pfh->pf_fd; | ||||
|  | ||||
| 	/* | ||||
| 	 * Truncate PID file, so multiple calls of pidfile_write() are allowed. | ||||
| 	 */ | ||||
| 	if (ftruncate(fd, 0) == -1) { | ||||
| 		error = errno; | ||||
| 		_pidfile_remove(pfh, 0); | ||||
| 		errno = error; | ||||
| 		return (-1); | ||||
| 	} | ||||
|  | ||||
| 	snprintf(pidstr, sizeof(pidstr), "%u", getpid()); | ||||
| 	if (pwrite(fd, pidstr, strlen(pidstr), 0) != (ssize_t)strlen(pidstr)) { | ||||
| 		error = errno; | ||||
| 		_pidfile_remove(pfh, 0); | ||||
| 		errno = error; | ||||
| 		return (-1); | ||||
| 	} | ||||
|  | ||||
| 	return (0); | ||||
| } | ||||
|  | ||||
| int | ||||
| pidfile_close(struct pidfh *pfh) | ||||
| { | ||||
| 	int error; | ||||
|  | ||||
| 	error = pidfile_verify(pfh); | ||||
| 	if (error != 0) { | ||||
| 		errno = error; | ||||
| 		return (-1); | ||||
| 	} | ||||
|  | ||||
| 	if (close(pfh->pf_fd) == -1) | ||||
| 		error = errno; | ||||
| 	free(pfh->pf_path); | ||||
| 	free(pfh); | ||||
| 	if (error != 0) { | ||||
| 		errno = error; | ||||
| 		return (-1); | ||||
| 	} | ||||
| 	return (0); | ||||
| } | ||||
|  | ||||
| static int | ||||
| _pidfile_remove(struct pidfh *pfh, int freeit) | ||||
| { | ||||
| 	int error; | ||||
|  | ||||
| 	error = pidfile_verify(pfh); | ||||
| 	if (error != 0) { | ||||
| 		errno = error; | ||||
| 		return (-1); | ||||
| 	} | ||||
|  | ||||
| 	if (unlink(pfh->pf_path) == -1) | ||||
| 		error = errno; | ||||
| 	if (close(pfh->pf_fd) == -1) { | ||||
| 		if (error == 0) | ||||
| 			error = errno; | ||||
| 	} | ||||
| 	if (freeit) { | ||||
| 		free(pfh->pf_path); | ||||
| 		free(pfh); | ||||
| 	} else | ||||
| 		pfh->pf_fd = -1; | ||||
| 	if (error != 0) { | ||||
| 		errno = error; | ||||
| 		return (-1); | ||||
| 	} | ||||
| 	return (0); | ||||
| } | ||||
|  | ||||
| int | ||||
| pidfile_remove(struct pidfh *pfh) | ||||
| { | ||||
|  | ||||
| 	return (_pidfile_remove(pfh, 1)); | ||||
| } | ||||
| @@ -1,5 +1,6 @@ | ||||
| /* | ||||
|  * Copyright © 2006 Robert Millan | ||||
|  * Copyright © 2010-2012 Guillem Jover <guillem@hadrons.org> | ||||
|  * | ||||
|  * Redistribution and use in source and binary forms, with or without | ||||
|  * modification, are permitted provided that the following conditions | ||||
| @@ -28,18 +29,39 @@ | ||||
|   Rejected in glibc (http://sourceware.org/ml/libc-alpha/2006-03/msg00125.html) | ||||
| */ | ||||
|  | ||||
| #include <bsd/stdlib.h> | ||||
| #include <errno.h> | ||||
| #include <string.h> | ||||
| #include <stdlib.h> | ||||
|  | ||||
| static char *__progname = NULL; | ||||
| #ifdef HAVE___PROGNAME | ||||
| extern const char *__progname; | ||||
| #else | ||||
| static const char *__progname = NULL; | ||||
| #endif | ||||
|  | ||||
| char * | ||||
| getprogname () | ||||
| const char * | ||||
| getprogname(void) | ||||
| { | ||||
|   return __progname; | ||||
| #if defined(HAVE_PROGRAM_INVOCATION_SHORT_NAME) | ||||
| 	if (__progname == NULL) | ||||
| 		__progname = program_invocation_short_name; | ||||
| #elif defined(HAVE_GETEXECNAME) | ||||
| 	/* getexecname(3) returns an absolute pathname, normalize it. */ | ||||
| 	if (__progname == NULL) | ||||
| 		setprogname(getexecname()); | ||||
| #endif | ||||
|  | ||||
| 	return __progname; | ||||
| } | ||||
|  | ||||
| void | ||||
| setprogname (char *new) | ||||
| setprogname(const char *progname) | ||||
| { | ||||
|   __progname = new; | ||||
| 	const char *last_slash; | ||||
|  | ||||
| 	last_slash = strrchr(progname, '/'); | ||||
| 	if (last_slash == NULL) | ||||
| 		__progname = progname; | ||||
| 	else | ||||
| 		__progname = last_slash + 1; | ||||
| } | ||||
|   | ||||
							
								
								
									
										319
									
								
								src/radixsort.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										319
									
								
								src/radixsort.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,319 @@ | ||||
| /*     $NetBSD: radixsort.c,v 1.18 2009/08/21 20:49:50 dsl Exp $       */ | ||||
| /*- | ||||
|  * Copyright (c) 1990, 1993 | ||||
|  *	The Regents of the University of California.  All rights reserved. | ||||
|  * | ||||
|  * This code is derived from software contributed to Berkeley by | ||||
|  * Peter McIlroy and by Dan Bernstein at New York University, | ||||
|  * | ||||
|  * 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. Neither the name of the University nor the names of its contributors | ||||
|  *    may be used to endorse or promote products derived from this software | ||||
|  *    without specific prior written permission. | ||||
|  * | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``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 REGENTS OR CONTRIBUTORS 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. | ||||
|  */ | ||||
|  | ||||
| #include <sys/cdefs.h> | ||||
| #if defined(LIBC_SCCS) && !defined(lint) | ||||
| #if 0 | ||||
| static char sccsid[] = "@(#)radixsort.c	8.2 (Berkeley) 4/28/95"; | ||||
| #else | ||||
| __RCSID("$NetBSD: radixsort.c,v 1.18 2009/08/21 20:49:50 dsl Exp $"); | ||||
| #endif | ||||
| #endif /* LIBC_SCCS and not lint */ | ||||
|  | ||||
| /* | ||||
|  * Radixsort routines. | ||||
|  * | ||||
|  * Program r_sort_a() is unstable but uses O(logN) extra memory for a stack. | ||||
|  * Use radixsort(a, n, trace, endchar) for this case. | ||||
|  * | ||||
|  * For stable sorting (using N extra pointers) use sradixsort(), which calls | ||||
|  * r_sort_b(). | ||||
|  * | ||||
|  * For a description of this code, see D. McIlroy, P. McIlroy, K. Bostic, | ||||
|  * "Engineering Radix Sort". | ||||
|  */ | ||||
|  | ||||
| #include <sys/types.h> | ||||
| #include <stdlib.h> | ||||
| #include <stddef.h> | ||||
| #include <errno.h> | ||||
|  | ||||
| typedef struct { | ||||
| 	const u_char **sa; | ||||
| 	int sn, si; | ||||
| } stack; | ||||
|  | ||||
| static inline void simplesort(const u_char **, int, int, const u_char *, u_int); | ||||
| static void r_sort_a(const u_char **, int, int, const u_char *, u_int); | ||||
| static void r_sort_b(const u_char **, | ||||
| 	    const u_char **, int, int, const u_char *, u_int); | ||||
|  | ||||
| #define	THRESHOLD	20		/* Divert to simplesort(). */ | ||||
| #define	SIZE		512		/* Default stack size. */ | ||||
|  | ||||
| #define SETUP {								\ | ||||
| 	if (tab == NULL) {						\ | ||||
| 		tr = tr0;						\ | ||||
| 		for (c = 0; c < endch; c++)				\ | ||||
| 			tr0[c] = c + 1;					\ | ||||
| 		tr0[c] = 0;						\ | ||||
| 		for (c++; c < 256; c++)					\ | ||||
| 			tr0[c] = c;					\ | ||||
| 		endch = 0;						\ | ||||
| 	} else {							\ | ||||
| 		endch = tab[endch];					\ | ||||
| 		tr = tab;						\ | ||||
| 		if (endch != 0 && endch != 255) {			\ | ||||
| 			errno = EINVAL;					\ | ||||
| 			return (-1);					\ | ||||
| 		}							\ | ||||
| 	}								\ | ||||
| } | ||||
|  | ||||
| int | ||||
| radixsort(const u_char **a, int n, const u_char *tab, u_int endch) | ||||
| { | ||||
| 	const u_char *tr; | ||||
| 	u_int c; | ||||
| 	u_char tr0[256]; | ||||
|  | ||||
| 	SETUP; | ||||
| 	r_sort_a(a, n, 0, tr, endch); | ||||
| 	return (0); | ||||
| } | ||||
|  | ||||
| int | ||||
| sradixsort(const u_char **a, int n, const u_char *tab, u_int endch) | ||||
| { | ||||
| 	const u_char *tr, **ta; | ||||
| 	u_int c; | ||||
| 	u_char tr0[256]; | ||||
|  | ||||
| 	if (a == NULL) { | ||||
| 		errno = EFAULT; | ||||
| 		return (-1); | ||||
| 	} | ||||
|  | ||||
| 	SETUP; | ||||
| 	if (n < THRESHOLD) | ||||
| 		simplesort(a, n, 0, tr, endch); | ||||
| 	else { | ||||
| 		if ((ta = malloc(n * sizeof(a))) == NULL) | ||||
| 			return (-1); | ||||
| 		r_sort_b(a, ta, n, 0, tr, endch); | ||||
| 		free(ta); | ||||
| 	} | ||||
| 	return (0); | ||||
| } | ||||
|  | ||||
| #define empty(s)	(s >= sp) | ||||
| #define pop(a, n, i)	a = (--sp)->sa, n = sp->sn, i = sp->si | ||||
| #define push(a, n, i)	sp->sa = a, sp->sn = n, (sp++)->si = i | ||||
| #define swap(a, b, t)	t = a, a = b, b = t | ||||
|  | ||||
| /* Unstable, in-place sort. */ | ||||
| static void | ||||
| r_sort_a(const u_char **a, int n, int i, const u_char *tr, u_int endch) | ||||
| { | ||||
| 	static u_int count[256], nc, bmin; | ||||
| 	u_int c; | ||||
| 	const u_char **ak, *r; | ||||
| 	stack s[SIZE], *sp, *sp0, *sp1, temp; | ||||
| 	u_int *cp, bigc; | ||||
| 	const u_char **an, *t, **aj, **top[256]; | ||||
|  | ||||
| 	/* Set up stack. */ | ||||
| 	sp = s; | ||||
| 	push(a, n, i); | ||||
| 	while (!empty(s)) { | ||||
| 		pop(a, n, i); | ||||
| 		if (n < THRESHOLD) { | ||||
| 			simplesort(a, n, i, tr, endch); | ||||
| 			continue; | ||||
| 		} | ||||
| 		an = a + n; | ||||
|  | ||||
| 		/* Make character histogram. */ | ||||
| 		if (nc == 0) { | ||||
| 			bmin = 255;	/* First occupied bin, excluding eos. */ | ||||
| 			for (ak = a; ak < an;) { | ||||
| 				c = tr[(*ak++)[i]]; | ||||
| 				if (++count[c] == 1 && c != endch) { | ||||
| 					if (c < bmin) | ||||
| 						bmin = c; | ||||
| 					nc++; | ||||
| 				} | ||||
| 			} | ||||
| 			if (sp + nc > s + SIZE) {	/* Get more stack. */ | ||||
| 				r_sort_a(a, n, i, tr, endch); | ||||
| 				continue; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		/* | ||||
| 		 * Special case: if all strings have the same | ||||
| 		 * character at position i, move on to the next | ||||
| 		 * character. | ||||
| 		 */ | ||||
| 		if (nc == 1 && count[bmin] == (u_int)n) { | ||||
| 			push(a, n, i+1); | ||||
| 			nc = count[bmin] = 0; | ||||
| 			continue; | ||||
| 		} | ||||
|  | ||||
| 		/* | ||||
| 		 * Set top[]; push incompletely sorted bins onto stack. | ||||
| 		 * top[] = pointers to last out-of-place element in bins. | ||||
| 		 * count[] = counts of elements in bins. | ||||
| 		 * Before permuting: top[c-1] + count[c] = top[c]; | ||||
| 		 * during deal: top[c] counts down to top[c-1]. | ||||
| 		 */ | ||||
| 		sp0 = sp1 = sp;		/* Stack position of biggest bin. */ | ||||
| 		bigc = 2;		/* Size of biggest bin. */ | ||||
| 		if (endch == 0)		/* Special case: set top[eos]. */ | ||||
| 			top[0] = ak = a + count[0]; | ||||
| 		else { | ||||
| 			ak = a; | ||||
| 			top[255] = an; | ||||
| 		} | ||||
| 		for (cp = count + bmin; nc > 0; cp++) { | ||||
| 			while (*cp == 0)	/* Find next non-empty pile. */ | ||||
| 				cp++; | ||||
| 			if (*cp > 1) { | ||||
| 				if (*cp > bigc) { | ||||
| 					bigc = *cp; | ||||
| 					sp1 = sp; | ||||
| 				} | ||||
| 				push(ak, *cp, i+1); | ||||
| 			} | ||||
| 			top[cp-count] = ak += *cp; | ||||
| 			nc--; | ||||
| 		} | ||||
| 		swap(*sp0, *sp1, temp);	/* Play it safe -- biggest bin last. */ | ||||
|  | ||||
| 		/* | ||||
| 		 * Permute misplacements home.  Already home: everything | ||||
| 		 * before aj, and in bin[c], items from top[c] on. | ||||
| 		 * Inner loop: | ||||
| 		 *	r = next element to put in place; | ||||
| 		 *	ak = top[r[i]] = location to put the next element. | ||||
| 		 *	aj = bottom of 1st disordered bin. | ||||
| 		 * Outer loop: | ||||
| 		 *	Once the 1st disordered bin is done, ie. aj >= ak, | ||||
| 		 *	aj<-aj + count[c] connects the bins in a linked list; | ||||
| 		 *	reset count[c]. | ||||
| 		 */ | ||||
| 		for (aj = a; aj < an;  *aj = r, aj += count[c], count[c] = 0) | ||||
| 			for (r = *aj;  aj < (ak = --top[c = tr[r[i]]]);) | ||||
| 				swap(*ak, r, t); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| /* Stable sort, requiring additional memory. */ | ||||
| static void | ||||
| r_sort_b(const u_char **a, const u_char **ta, int n, int i, const u_char *tr, | ||||
|     u_int endch) | ||||
| { | ||||
| 	static u_int count[256], nc, bmin; | ||||
| 	u_int c; | ||||
| 	const u_char **ak, **ai; | ||||
| 	stack s[512], *sp, *sp0, *sp1, temp; | ||||
| 	const u_char **top[256]; | ||||
| 	u_int *cp, bigc; | ||||
|  | ||||
| 	sp = s; | ||||
| 	push(a, n, i); | ||||
| 	while (!empty(s)) { | ||||
| 		pop(a, n, i); | ||||
| 		if (n < THRESHOLD) { | ||||
| 			simplesort(a, n, i, tr, endch); | ||||
| 			continue; | ||||
| 		} | ||||
|  | ||||
| 		if (nc == 0) { | ||||
| 			bmin = 255; | ||||
| 			for (ak = a + n; --ak >= a;) { | ||||
| 				c = tr[(*ak)[i]]; | ||||
| 				if (++count[c] == 1 && c != endch) { | ||||
| 					if (c < bmin) | ||||
| 						bmin = c; | ||||
| 					nc++; | ||||
| 				} | ||||
| 			} | ||||
| 			if (sp + nc > s + SIZE) { | ||||
| 				r_sort_b(a, ta, n, i, tr, endch); | ||||
| 				continue; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		sp0 = sp1 = sp; | ||||
| 		bigc = 2; | ||||
| 		if (endch == 0) { | ||||
| 			top[0] = ak = a + count[0]; | ||||
| 			count[0] = 0; | ||||
| 		} else { | ||||
| 			ak = a; | ||||
| 			top[255] = a + n; | ||||
| 			count[255] = 0; | ||||
| 		} | ||||
| 		for (cp = count + bmin; nc > 0; cp++) { | ||||
| 			while (*cp == 0) | ||||
| 				cp++; | ||||
| 			if ((c = *cp) > 1) { | ||||
| 				if (c > bigc) { | ||||
| 					bigc = c; | ||||
| 					sp1 = sp; | ||||
| 				} | ||||
| 				push(ak, c, i+1); | ||||
| 			} | ||||
| 			top[cp-count] = ak += c; | ||||
| 			*cp = 0;			/* Reset count[]. */ | ||||
| 			nc--; | ||||
| 		} | ||||
| 		swap(*sp0, *sp1, temp); | ||||
|  | ||||
| 		for (ak = ta + n, ai = a+n; ak > ta;)	/* Copy to temp. */ | ||||
| 			*--ak = *--ai; | ||||
| 		for (ak = ta+n; --ak >= ta;)		/* Deal to piles. */ | ||||
| 			*--top[tr[(*ak)[i]]] = *ak; | ||||
| 	} | ||||
| } | ||||
|  | ||||
| /* insertion sort */ | ||||
| static inline void | ||||
| simplesort(const u_char **a, int n, int b, const u_char *tr, u_int endch) | ||||
| { | ||||
| 	u_char ch; | ||||
| 	const u_char  **ak, **ai, *s, *t; | ||||
|  | ||||
| 	for (ak = a+1; --n >= 1; ak++) | ||||
| 		for (ai = ak; ai > a; ai--) { | ||||
| 			for (s = ai[0] + b, t = ai[-1] + b; | ||||
| 			    (ch = tr[*s]) != endch; s++, t++) | ||||
| 				if (ch != tr[*t]) | ||||
| 					break; | ||||
| 			if (ch >= tr[*t]) | ||||
| 				break; | ||||
| 			swap(ai[0], ai[-1], s); | ||||
| 		} | ||||
| } | ||||
							
								
								
									
										187
									
								
								src/readpassphrase.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										187
									
								
								src/readpassphrase.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,187 @@ | ||||
| /*	$OpenBSD: readpassphrase.c,v 1.20 2007/10/30 12:03:48 millert Exp $	*/ | ||||
|  | ||||
| /* | ||||
|  * Copyright (c) 2000-2002, 2007 Todd C. Miller <Todd.Miller@courtesan.com> | ||||
|  * | ||||
|  * Permission to use, copy, modify, and distribute this software for any | ||||
|  * purpose with or without fee is hereby granted, provided that the above | ||||
|  * copyright notice and this permission notice appear in all copies. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | ||||
|  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | ||||
|  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | ||||
|  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | ||||
|  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | ||||
|  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF | ||||
|  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||||
|  * | ||||
|  * Sponsored in part by the Defense Advanced Research Projects | ||||
|  * Agency (DARPA) and Air Force Research Laboratory, Air Force | ||||
|  * Materiel Command, USAF, under agreement number F39502-99-1-0512. | ||||
|  */ | ||||
|  | ||||
| #include <ctype.h> | ||||
| #include <errno.h> | ||||
| #include <fcntl.h> | ||||
| #include <paths.h> | ||||
| #include <pwd.h> | ||||
| #include <signal.h> | ||||
| #include <string.h> | ||||
| #include <termios.h> | ||||
| #include <unistd.h> | ||||
| #include <readpassphrase.h> | ||||
|  | ||||
| #ifndef TCSASOFT | ||||
| #define TCSASOFT 0 | ||||
| #endif | ||||
|  | ||||
| static volatile sig_atomic_t signo; | ||||
|  | ||||
| static void handler(int); | ||||
|  | ||||
| char * | ||||
| readpassphrase(const char *prompt, char *buf, size_t bufsiz, int flags) | ||||
| { | ||||
| 	ssize_t nr; | ||||
| 	int input, output, save_errno; | ||||
| 	char ch, *p, *end; | ||||
| 	struct termios term, oterm; | ||||
| 	struct sigaction sa, savealrm, saveint, savehup, savequit, saveterm; | ||||
| 	struct sigaction savetstp, savettin, savettou, savepipe; | ||||
|  | ||||
| 	/* I suppose we could alloc on demand in this case (XXX). */ | ||||
| 	if (bufsiz == 0) { | ||||
| 		errno = EINVAL; | ||||
| 		return(NULL); | ||||
| 	} | ||||
|  | ||||
| restart: | ||||
| 	signo = 0; | ||||
| 	nr = -1; | ||||
| 	save_errno = 0; | ||||
| 	/* | ||||
| 	 * Read and write to /dev/tty if available.  If not, read from | ||||
| 	 * stdin and write to stderr unless a tty is required. | ||||
| 	 */ | ||||
| 	if ((flags & RPP_STDIN) || | ||||
| 	    (input = output = open(_PATH_TTY, O_RDWR)) == -1) { | ||||
| 		if (flags & RPP_REQUIRE_TTY) { | ||||
| 			errno = ENOTTY; | ||||
| 			return(NULL); | ||||
| 		} | ||||
| 		input = STDIN_FILENO; | ||||
| 		output = STDERR_FILENO; | ||||
| 	} | ||||
|  | ||||
| 	/* | ||||
| 	 * Catch signals that would otherwise cause the user to end | ||||
| 	 * up with echo turned off in the shell.  Don't worry about | ||||
| 	 * things like SIGXCPU and SIGVTALRM for now. | ||||
| 	 */ | ||||
| 	sigemptyset(&sa.sa_mask); | ||||
| 	sa.sa_flags = 0;		/* don't restart system calls */ | ||||
| 	sa.sa_handler = handler; | ||||
| 	(void)sigaction(SIGALRM, &sa, &savealrm); | ||||
| 	(void)sigaction(SIGHUP, &sa, &savehup); | ||||
| 	(void)sigaction(SIGINT, &sa, &saveint); | ||||
| 	(void)sigaction(SIGPIPE, &sa, &savepipe); | ||||
| 	(void)sigaction(SIGQUIT, &sa, &savequit); | ||||
| 	(void)sigaction(SIGTERM, &sa, &saveterm); | ||||
| 	(void)sigaction(SIGTSTP, &sa, &savetstp); | ||||
| 	(void)sigaction(SIGTTIN, &sa, &savettin); | ||||
| 	(void)sigaction(SIGTTOU, &sa, &savettou); | ||||
|  | ||||
| 	/* Turn off echo if possible. */ | ||||
| 	if (input != STDIN_FILENO && tcgetattr(input, &oterm) == 0) { | ||||
| 		memcpy(&term, &oterm, sizeof(term)); | ||||
| 		if (!(flags & RPP_ECHO_ON)) | ||||
| 			term.c_lflag &= ~(ECHO | ECHONL); | ||||
| #ifdef VSTATUS | ||||
| 		if (term.c_cc[VSTATUS] != _POSIX_VDISABLE) | ||||
| 			term.c_cc[VSTATUS] = _POSIX_VDISABLE; | ||||
| #endif | ||||
| 		(void)tcsetattr(input, TCSAFLUSH|TCSASOFT, &term); | ||||
| 	} else { | ||||
| 		memset(&term, 0, sizeof(term)); | ||||
| 		term.c_lflag |= ECHO; | ||||
| 		memset(&oterm, 0, sizeof(oterm)); | ||||
| 		oterm.c_lflag |= ECHO; | ||||
| 	} | ||||
|  | ||||
| 	/* No I/O if we are already backgrounded. */ | ||||
| 	if (signo != SIGTTOU && signo != SIGTTIN) { | ||||
| 		if (!(flags & RPP_STDIN)) | ||||
| 			(void)write(output, prompt, strlen(prompt)); | ||||
| 		end = buf + bufsiz - 1; | ||||
| 		p = buf; | ||||
| 		while ((nr = read(input, &ch, 1)) == 1 && ch != '\n' && ch != '\r') { | ||||
| 			if (p < end) { | ||||
| 				if ((flags & RPP_SEVENBIT)) | ||||
| 					ch &= 0x7f; | ||||
| 				if (isalpha(ch)) { | ||||
| 					if ((flags & RPP_FORCELOWER)) | ||||
| 						ch = (char)tolower(ch); | ||||
| 					if ((flags & RPP_FORCEUPPER)) | ||||
| 						ch = (char)toupper(ch); | ||||
| 				} | ||||
| 				*p++ = ch; | ||||
| 			} | ||||
| 		} | ||||
| 		*p = '\0'; | ||||
| 		save_errno = errno; | ||||
| 		if (!(term.c_lflag & ECHO)) | ||||
| 			(void)write(output, "\n", 1); | ||||
| 	} | ||||
|  | ||||
| 	/* Restore old terminal settings and signals. */ | ||||
| 	if (memcmp(&term, &oterm, sizeof(term)) != 0) { | ||||
| 		while (tcsetattr(input, TCSAFLUSH|TCSASOFT, &oterm) == -1 && | ||||
| 		    errno == EINTR) | ||||
| 			continue; | ||||
| 	} | ||||
| 	(void)sigaction(SIGALRM, &savealrm, NULL); | ||||
| 	(void)sigaction(SIGHUP, &savehup, NULL); | ||||
| 	(void)sigaction(SIGINT, &saveint, NULL); | ||||
| 	(void)sigaction(SIGQUIT, &savequit, NULL); | ||||
| 	(void)sigaction(SIGPIPE, &savepipe, NULL); | ||||
| 	(void)sigaction(SIGTERM, &saveterm, NULL); | ||||
| 	(void)sigaction(SIGTSTP, &savetstp, NULL); | ||||
| 	(void)sigaction(SIGTTIN, &savettin, NULL); | ||||
| 	(void)sigaction(SIGTTOU, &savettou, NULL); | ||||
| 	if (input != STDIN_FILENO) | ||||
| 		(void)close(input); | ||||
|  | ||||
| 	/* | ||||
| 	 * If we were interrupted by a signal, resend it to ourselves | ||||
| 	 * now that we have restored the signal handlers. | ||||
| 	 */ | ||||
| 	if (signo) { | ||||
| 		kill(getpid(), signo); | ||||
| 		switch (signo) { | ||||
| 		case SIGTSTP: | ||||
| 		case SIGTTIN: | ||||
| 		case SIGTTOU: | ||||
| 			goto restart; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	if (save_errno) | ||||
| 		errno = save_errno; | ||||
| 	return(nr == -1 ? NULL : buf); | ||||
| } | ||||
|  | ||||
| #if 0 | ||||
| char * | ||||
| getpass(const char *prompt) | ||||
| { | ||||
| 	static char buf[_PASSWORD_LEN + 1]; | ||||
|  | ||||
| 	return(readpassphrase(prompt, buf, sizeof(buf), RPP_ECHO_OFF)); | ||||
| } | ||||
| #endif | ||||
|  | ||||
| static void handler(int s) | ||||
| { | ||||
|  | ||||
| 	signo = s; | ||||
| } | ||||
							
								
								
									
										48
									
								
								src/reallocf.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										48
									
								
								src/reallocf.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,48 @@ | ||||
| /*- | ||||
|  * Copyright (c) 1998, M. Warner Losh <imp@freebsd.org> | ||||
|  * All rights reserved. | ||||
|  * | ||||
|  * 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. | ||||
|  * | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``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 OR CONTRIBUTORS 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. | ||||
|  */ | ||||
|  | ||||
| #include <sys/cdefs.h> | ||||
| __FBSDID("$FreeBSD$"); | ||||
|  | ||||
| #include <stdlib.h> | ||||
|  | ||||
| void * | ||||
| reallocf(void *ptr, size_t size) | ||||
| { | ||||
| 	void *nptr; | ||||
|  | ||||
| 	nptr = realloc(ptr, size); | ||||
|  | ||||
| 	/* | ||||
| 	 * When the System V compatibility option (malloc "V" flag) is | ||||
| 	 * in effect, realloc(ptr, 0) frees the memory and returns NULL. | ||||
| 	 * So, to avoid double free, call free() only when size != 0. | ||||
| 	 * realloc(ptr, 0) can't fail when ptr != NULL. | ||||
| 	 */ | ||||
| 	if (!nptr && ptr && size != 0) | ||||
| 		free(ptr); | ||||
| 	return (nptr); | ||||
| } | ||||
| @@ -1,3 +1,5 @@ | ||||
| /*	$NetBSD: setmode.c,v 1.34 2012/06/25 22:32:43 abs Exp $	*/ | ||||
|  | ||||
| /* | ||||
|  * Copyright (c) 1989, 1993, 1994 | ||||
|  *	The Regents of the University of California.  All rights reserved. | ||||
| @@ -13,7 +15,7 @@ | ||||
|  * 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. | ||||
|  * 4. Neither the name of the University nor the names of its contributors | ||||
|  * 3. Neither the name of the University nor the names of its contributors | ||||
|  *    may be used to endorse or promote products derived from this software | ||||
|  *    without specific prior written permission. | ||||
|  * | ||||
| @@ -30,19 +32,23 @@ | ||||
|  * SUCH DAMAGE. | ||||
|  */ | ||||
|  | ||||
| #if defined(LIBC_SCCS) && !defined(lint) | ||||
| static char sccsid[] = "@(#)setmode.c	8.2 (Berkeley) 3/25/94"; | ||||
| #endif /* LIBC_SCCS and not lint */ | ||||
| #include <sys/cdefs.h> | ||||
| __FBSDID("$FreeBSD: src/lib/libc/gen/setmode.c,v 1.11 2007/01/09 00:27:55 imp Exp $"); | ||||
| #if defined(LIBC_SCCS) && !defined(lint) | ||||
| #if 0 | ||||
| static char sccsid[] = "@(#)setmode.c	8.2 (Berkeley) 3/25/94"; | ||||
| #else | ||||
| __RCSID("$NetBSD: setmode.c,v 1.34 2012/06/25 22:32:43 abs Exp $"); | ||||
| #endif | ||||
| #endif /* LIBC_SCCS and not lint */ | ||||
|  | ||||
| #include <sys/types.h> | ||||
| #include <sys/stat.h> | ||||
|  | ||||
| #include <ctype.h> | ||||
| #include <errno.h> | ||||
| #include <signal.h> | ||||
| #include <stddef.h> | ||||
| #include <stdlib.h> | ||||
| #include <limits.h> | ||||
| #include <unistd.h> | ||||
|  | ||||
| #ifdef SETMODE_DEBUG | ||||
| @@ -64,7 +70,7 @@ typedef struct bitcmd { | ||||
| #define	CMD2_OBITS	0x08 | ||||
| #define	CMD2_UBITS	0x10 | ||||
|  | ||||
| static BITCMD	*addcmd(BITCMD *, int, int, int, u_int); | ||||
| static BITCMD	*addcmd(BITCMD *, mode_t, mode_t, mode_t, mode_t); | ||||
| static void	 compress_mode(BITCMD *); | ||||
| #ifdef SETMODE_DEBUG | ||||
| static void	 dumpmode(BITCMD *); | ||||
| @@ -144,38 +150,38 @@ common:			if (set->cmd2 & CMD2_CLR) { | ||||
| 		} | ||||
| } | ||||
|  | ||||
| #define	ADDCMD(a, b, c, d)						\ | ||||
| #define	ADDCMD(a, b, c, d) do {						\ | ||||
| 	if (set >= endset) {						\ | ||||
| 		BITCMD *newset;						\ | ||||
| 		setlen += SET_LEN_INCR;					\ | ||||
| 		newset = realloc(saveset, sizeof(BITCMD) * setlen);	\ | ||||
| 		if (!newset) {						\ | ||||
| 			if (saveset)					\ | ||||
| 				free(saveset);				\ | ||||
| 			saveset = NULL;					\ | ||||
| 			return (NULL);					\ | ||||
| 		}							\ | ||||
| 		if (newset == NULL)					\ | ||||
| 			goto out;					\ | ||||
| 		set = newset + (set - saveset);				\ | ||||
| 		saveset = newset;					\ | ||||
| 		endset = newset + (setlen - 2);				\ | ||||
| 	}								\ | ||||
| 	set = addcmd(set, (a), (b), (c), (d)) | ||||
| 	set = addcmd(set, (mode_t)(a), (mode_t)(b), (mode_t)(c), (d));	\ | ||||
| } while (/*CONSTCOND*/0) | ||||
|  | ||||
| #define	STANDARD_BITS	(S_ISUID|S_ISGID|S_IRWXU|S_IRWXG|S_IRWXO) | ||||
|  | ||||
| void * | ||||
| setmode(const char *p) | ||||
| { | ||||
| 	int perm, who; | ||||
| 	int serrno; | ||||
| 	char op, *ep; | ||||
| 	BITCMD *set, *saveset, *endset; | ||||
| 	sigset_t sigset, sigoset; | ||||
| 	mode_t mask; | ||||
| 	int equalopdone=0, permXbits, setlen; | ||||
| 	long perml; | ||||
| 	sigset_t signset, sigoset; | ||||
| 	mode_t mask, perm, permXbits, who; | ||||
| 	long lval; | ||||
| 	int equalopdone = 0;	/* pacify gcc */ | ||||
| 	int setlen; | ||||
|  | ||||
| 	if (!*p) | ||||
| 		return (NULL); | ||||
| 	if (!*p) { | ||||
| 		errno = EINVAL; | ||||
| 		return NULL; | ||||
| 	} | ||||
|  | ||||
| 	/* | ||||
| 	 * Get a copy of the mask for the permissions that are mask relative. | ||||
| @@ -183,8 +189,8 @@ setmode(const char *p) | ||||
| 	 * the caller is opening files inside a signal handler, protect them | ||||
| 	 * as best we can. | ||||
| 	 */ | ||||
| 	sigfillset(&sigset); | ||||
| 	(void)sigprocmask(SIG_BLOCK, &sigset, &sigoset); | ||||
| 	sigfillset(&signset); | ||||
| 	(void)sigprocmask(SIG_BLOCK, &signset, &sigoset); | ||||
| 	(void)umask(mask = umask(0)); | ||||
| 	mask = ~mask; | ||||
| 	(void)sigprocmask(SIG_SETMASK, &sigoset, NULL); | ||||
| @@ -201,12 +207,19 @@ setmode(const char *p) | ||||
| 	 * or illegal bits. | ||||
| 	 */ | ||||
| 	if (isdigit((unsigned char)*p)) { | ||||
| 		perml = strtol(p, &ep, 8); | ||||
| 		if (*ep || perml < 0 || perml & ~(STANDARD_BITS|S_ISTXT)) { | ||||
| 			free(saveset); | ||||
| 			return (NULL); | ||||
| 		errno = 0; | ||||
| 		lval = strtol(p, &ep, 8); | ||||
| 		if (*ep) { | ||||
| 			errno = EINVAL; | ||||
| 			goto out; | ||||
| 		} | ||||
| 		perm = (mode_t)perml; | ||||
| 		if (errno == ERANGE && (lval == LONG_MAX || lval == LONG_MIN)) | ||||
| 			goto out; | ||||
| 		if (lval & ~(STANDARD_BITS|S_ISTXT)) { | ||||
| 			errno = EINVAL; | ||||
| 			goto out; | ||||
| 		} | ||||
| 		perm = (mode_t)lval; | ||||
| 		ADDCMD('=', (STANDARD_BITS|S_ISTXT), perm, mask); | ||||
| 		set->cmd = 0; | ||||
| 		return (saveset); | ||||
| @@ -238,8 +251,8 @@ setmode(const char *p) | ||||
| 		} | ||||
|  | ||||
| getop:		if ((op = *p++) != '+' && op != '-' && op != '=') { | ||||
| 			free(saveset); | ||||
| 			return (NULL); | ||||
| 			errno = EINVAL; | ||||
| 			goto out; | ||||
| 		} | ||||
| 		if (op == '=') | ||||
| 			equalopdone = 0; | ||||
| @@ -251,13 +264,19 @@ getop:		if ((op = *p++) != '+' && op != '-' && op != '=') { | ||||
| 				perm |= S_IRUSR|S_IRGRP|S_IROTH; | ||||
| 				break; | ||||
| 			case 's': | ||||
| 				/* If only "other" bits ignore set-id. */ | ||||
| 				if (!who || who & ~S_IRWXO) | ||||
| 				/* | ||||
| 				 * If specific bits where requested and | ||||
| 				 * only "other" bits ignore set-id. | ||||
| 				 */ | ||||
| 				if (who == 0 || (who & ~S_IRWXO)) | ||||
| 					perm |= S_ISUID|S_ISGID; | ||||
| 				break; | ||||
| 			case 't': | ||||
| 				/* If only "other" bits ignore sticky. */ | ||||
| 				if (!who || who & ~S_IRWXO) { | ||||
| 				/* | ||||
| 				 * If specific bits where requested and | ||||
| 				 * only "other" bits ignore set-id. | ||||
| 				 */ | ||||
| 				if (who == 0 || (who & ~S_IRWXO)) { | ||||
| 					who |= S_ISTXT; | ||||
| 					perm |= S_ISTXT; | ||||
| 				} | ||||
| @@ -328,10 +347,15 @@ apply:		if (!*p) | ||||
| 	dumpmode(saveset); | ||||
| #endif | ||||
| 	return (saveset); | ||||
| out: | ||||
| 	serrno = errno; | ||||
| 	free(saveset); | ||||
| 	errno = serrno; | ||||
| 	return NULL; | ||||
| } | ||||
|  | ||||
| static BITCMD * | ||||
| addcmd(BITCMD *set, int op, int who, int oparg, u_int mask) | ||||
| addcmd(BITCMD *set, mode_t op, mode_t who, mode_t oparg, mode_t mask) | ||||
| { | ||||
| 	switch (op) { | ||||
| 	case '=': | ||||
|   | ||||
							
								
								
									
										255
									
								
								src/setproctitle.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										255
									
								
								src/setproctitle.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,255 @@ | ||||
| /* | ||||
|  * Copyright © 2010 William Ahern | ||||
|  * Copyright © 2012 Guillem Jover <guillem@hadrons.org> | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a | ||||
|  * copy of this software and associated documentation files (the | ||||
|  * "Software"), to deal in the Software without restriction, including | ||||
|  * without limitation the rights to use, copy, modify, merge, publish, | ||||
|  * distribute, sublicense, and/or sell copies of the Software, and to permit | ||||
|  * persons to whom the Software is furnished to do so, subject to the | ||||
|  * following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included | ||||
|  * in all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS | ||||
|  * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF | ||||
|  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN | ||||
|  * NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, | ||||
|  * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR | ||||
|  * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE | ||||
|  * USE OR OTHER DEALINGS IN THE SOFTWARE. | ||||
|  */ | ||||
|  | ||||
| #include <errno.h> | ||||
| #include <stddef.h> | ||||
| #include <stdarg.h> | ||||
| #include <stdbool.h> | ||||
| #include <stdlib.h> | ||||
| #include <stdio.h> | ||||
| #include <unistd.h> | ||||
| #include <string.h> | ||||
|  | ||||
| static struct { | ||||
| 	/* Original value. */ | ||||
| 	const char *arg0; | ||||
|  | ||||
| 	/* Title space available. */ | ||||
| 	char *base, *end; | ||||
|  | ||||
| 	 /* Pointer to original nul character within base. */ | ||||
| 	char *nul; | ||||
|  | ||||
| 	bool reset; | ||||
| 	int error; | ||||
| } SPT; | ||||
|  | ||||
|  | ||||
| static inline size_t | ||||
| spt_min(size_t a, size_t b) | ||||
| { | ||||
| 	return a < b ? a : b; | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * For discussion on the portability of the various methods, see | ||||
|  * http://lists.freebsd.org/pipermail/freebsd-stable/2008-June/043136.html | ||||
|  */ | ||||
| static int | ||||
| spt_clearenv(void) | ||||
| { | ||||
| #ifdef HAVE_CLEARENV | ||||
| 	return clearenv(); | ||||
| #else | ||||
| 	char **tmp; | ||||
|  | ||||
| 	tmp = malloc(sizeof(*tmp)); | ||||
| 	if (tmp == NULL) | ||||
| 		return errno; | ||||
|  | ||||
| 	tmp[0] = NULL; | ||||
| 	environ = tmp; | ||||
|  | ||||
| 	return 0; | ||||
| #endif | ||||
| } | ||||
|  | ||||
| static int | ||||
| spt_copyenv(char *oldenv[]) | ||||
| { | ||||
| 	char *eq; | ||||
| 	int i, error; | ||||
|  | ||||
| 	if (environ != oldenv) | ||||
| 		return 0; | ||||
|  | ||||
| 	error = spt_clearenv(); | ||||
| 	if (error) { | ||||
| 		environ = oldenv; | ||||
| 		return error; | ||||
| 	} | ||||
|  | ||||
| 	for (i = 0; oldenv[i]; i++) { | ||||
| 		eq = strchr(oldenv[i], '='); | ||||
| 		if (eq == NULL) | ||||
| 			continue; | ||||
|  | ||||
| 		*eq = '\0'; | ||||
| 		if (setenv(oldenv[i], eq + 1, 1) < 0) | ||||
| 			error = errno; | ||||
| 		*eq = '='; | ||||
|  | ||||
| 		if (error) { | ||||
| 			environ = oldenv; | ||||
| 			return error; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	return 0; | ||||
| } | ||||
|  | ||||
| static int | ||||
| spt_copyargs(int argc, char *argv[]) | ||||
| { | ||||
| 	char *tmp; | ||||
| 	int i; | ||||
|  | ||||
| 	for (i = 1; i < argc || (i >= argc && argv[i]); i++) { | ||||
| 		if (argv[i] == NULL) | ||||
| 			continue; | ||||
|  | ||||
| 		tmp = strdup(argv[i]); | ||||
| 		if (tmp == NULL) | ||||
| 			return errno; | ||||
|  | ||||
| 		argv[i] = tmp; | ||||
| 	} | ||||
|  | ||||
| 	return 0; | ||||
| } | ||||
|  | ||||
| static void __attribute__((constructor)) | ||||
| spt_init(int argc, char *argv[], char *envp[]) | ||||
| { | ||||
| 	char *base, *end, *nul, *tmp; | ||||
| 	int i, error; | ||||
|  | ||||
| 	base = argv[0]; | ||||
| 	if (base == NULL) | ||||
| 		return; | ||||
|  | ||||
| 	nul = &base[strlen(base)]; | ||||
| 	end = nul + 1; | ||||
|  | ||||
| 	for (i = 0; i < argc || (i >= argc && argv[i]); i++) { | ||||
| 		if (argv[i] == NULL || argv[i] < end) | ||||
| 			continue; | ||||
|  | ||||
| 		end = argv[i] + strlen(argv[i]) + 1; | ||||
| 	} | ||||
|  | ||||
| 	for (i = 0; envp[i]; i++) { | ||||
| 		if (envp[i] < end) | ||||
| 			continue; | ||||
|  | ||||
| 		end = envp[i] + strlen(envp[i]) + 1; | ||||
| 	} | ||||
|  | ||||
| 	SPT.arg0 = strdup(argv[0]); | ||||
| 	if (SPT.arg0 == NULL) { | ||||
| 		SPT.error = errno; | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| 	tmp = strdup(getprogname()); | ||||
| 	if (tmp == NULL) { | ||||
| 		SPT.error = errno; | ||||
| 		return; | ||||
| 	} | ||||
| 	setprogname(tmp); | ||||
|  | ||||
| 	error = spt_copyenv(envp); | ||||
| 	if (error) { | ||||
| 		SPT.error = error; | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| 	error = spt_copyargs(argc, argv); | ||||
| 	if (error) { | ||||
| 		SPT.error = error; | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| 	SPT.nul  = nul; | ||||
| 	SPT.base = base; | ||||
| 	SPT.end  = end; | ||||
| } | ||||
|  | ||||
| #ifndef SPT_MAXTITLE | ||||
| #define SPT_MAXTITLE 255 | ||||
| #endif | ||||
|  | ||||
| void | ||||
| setproctitle_impl(const char *fmt, ...) | ||||
| { | ||||
| 	/* Use buffer in case argv[0] is passed. */ | ||||
| 	char buf[SPT_MAXTITLE + 1]; | ||||
| 	va_list ap; | ||||
| 	char *nul; | ||||
| 	int len; | ||||
|  | ||||
| 	if (SPT.base == NULL) | ||||
| 		return; | ||||
|  | ||||
| 	if (fmt) { | ||||
| 		if (fmt[0] == '-') { | ||||
| 			/* Skip program name prefix. */ | ||||
| 			fmt++; | ||||
| 			len = 0; | ||||
| 		} else { | ||||
| 			/* Print program name heading for grep. */ | ||||
| 			snprintf(buf, sizeof(buf), "%s: ", getprogname()); | ||||
| 			len = strlen(buf); | ||||
| 		} | ||||
|  | ||||
| 		va_start(ap, fmt); | ||||
| 		len += vsnprintf(buf + len, sizeof(buf) - len, fmt, ap); | ||||
| 		va_end(ap); | ||||
| 	} else { | ||||
| 		len = snprintf(buf, sizeof(buf), "%s", SPT.arg0); | ||||
| 	} | ||||
|  | ||||
| 	if (len <= 0) { | ||||
| 		SPT.error = errno; | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| 	if (!SPT.reset) { | ||||
| 		memset(SPT.base, 0, SPT.end - SPT.base); | ||||
| 		SPT.reset = true; | ||||
| 	} else { | ||||
| 		memset(SPT.base, 0, spt_min(sizeof(buf), SPT.end - SPT.base)); | ||||
| 	} | ||||
|  | ||||
| 	len = spt_min(len, spt_min(sizeof(buf), SPT.end - SPT.base) - 1); | ||||
| 	memcpy(SPT.base, buf, len); | ||||
| 	nul = &SPT.base[len]; | ||||
|  | ||||
| 	if (nul < SPT.nul) { | ||||
| 		*SPT.nul = '.'; | ||||
| 	} else if (nul == SPT.nul && &nul[1] < SPT.end) { | ||||
| 		*SPT.nul = ' '; | ||||
| 		*++nul = '\0'; | ||||
| 	} | ||||
| } | ||||
| __asm__(".symver setproctitle_impl,setproctitle@@LIBBSD_0.5"); | ||||
|  | ||||
| #ifdef HAVE_TYPEOF | ||||
| /* The original function introduced in 0.2 was a stub, it only got implemented | ||||
|  * in 0.5, make the implementation available in the old version as an alias | ||||
|  * for code linking against that version, and change the default to use the | ||||
|  * new version, so that new code depends on the implemented version. */ | ||||
| extern typeof(setproctitle_impl) setproctitle_stub __attribute__((alias("setproctitle_impl"))); | ||||
| __asm__(".symver setproctitle_stub,setproctitle@LIBBSD_0.2"); | ||||
| #endif | ||||
| @@ -1,37 +1,21 @@ | ||||
| /*	$OpenBSD: strlcat.c,v 1.2 1999/06/17 16:28:58 millert Exp $	*/ | ||||
| /*	$OpenBSD: strlcat.c,v 1.12 2005/03/30 20:13:52 otto Exp $	*/ | ||||
|  | ||||
| /* | ||||
|  * Copyright (c) 1998 Todd C. Miller <Todd.Miller@courtesan.com> | ||||
|  * All rights reserved. | ||||
|  * | ||||
|  * 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. | ||||
|  * Permission to use, copy, modify, and distribute this software for any | ||||
|  * purpose with or without fee is hereby granted, provided that the above | ||||
|  * copyright notice and this permission notice appear in all copies. | ||||
|  * | ||||
|  * 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. | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | ||||
|  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | ||||
|  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | ||||
|  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | ||||
|  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | ||||
|  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF | ||||
|  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||||
|  */ | ||||
|  | ||||
| #if defined(LIBC_SCCS) && !defined(lint) | ||||
| static char *rcsid = "$OpenBSD: strlcat.c,v 1.2 1999/06/17 16:28:58 millert Exp $"); | ||||
| #endif /* LIBC_SCCS and not lint */ | ||||
| #include <sys/cdefs.h> | ||||
|  | ||||
| #include <sys/types.h> | ||||
| #include <string.h> | ||||
|  | ||||
| @@ -43,10 +27,7 @@ static char *rcsid = "$OpenBSD: strlcat.c,v 1.2 1999/06/17 16:28:58 millert Exp | ||||
|  * If retval >= siz, truncation occurred. | ||||
|  */ | ||||
| size_t | ||||
| strlcat(dst, src, siz) | ||||
| 	char *dst; | ||||
| 	const char *src; | ||||
| 	size_t siz; | ||||
| strlcat(char *dst, const char *src, size_t siz) | ||||
| { | ||||
| 	char *d = dst; | ||||
| 	const char *s = src; | ||||
|   | ||||
| @@ -1,37 +1,21 @@ | ||||
| /*	$OpenBSD: strlcpy.c,v 1.4 1999/05/01 18:56:41 millert Exp $	*/ | ||||
| /*	$OpenBSD: strlcpy.c,v 1.10 2005/08/08 08:05:37 espie Exp $	*/ | ||||
|  | ||||
| /* | ||||
|  * Copyright (c) 1998 Todd C. Miller <Todd.Miller@courtesan.com> | ||||
|  * All rights reserved. | ||||
|  * | ||||
|  * 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. | ||||
|  * Permission to use, copy, modify, and distribute this software for any | ||||
|  * purpose with or without fee is hereby granted, provided that the above | ||||
|  * copyright notice and this permission notice appear in all copies. | ||||
|  * | ||||
|  * 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. | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | ||||
|  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | ||||
|  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | ||||
|  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | ||||
|  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | ||||
|  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF | ||||
|  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||||
|  */ | ||||
|  | ||||
| #if defined(LIBC_SCCS) && !defined(lint) | ||||
| static char *rcsid = "$OpenBSD: strlcpy.c,v 1.4 1999/05/01 18:56:41 millert Exp $"); | ||||
| #endif /* LIBC_SCCS and not lint */ | ||||
| #include <sys/cdefs.h> | ||||
|  | ||||
| #include <sys/types.h> | ||||
| #include <string.h> | ||||
|  | ||||
| @@ -40,21 +24,19 @@ static char *rcsid = "$OpenBSD: strlcpy.c,v 1.4 1999/05/01 18:56:41 millert Exp | ||||
|  * will be copied.  Always NUL terminates (unless siz == 0). | ||||
|  * Returns strlen(src); if retval >= siz, truncation occurred. | ||||
|  */ | ||||
| size_t strlcpy(dst, src, siz) | ||||
| 	char *dst; | ||||
| 	const char *src; | ||||
| 	size_t siz; | ||||
| size_t | ||||
| strlcpy(char *dst, const char *src, size_t siz) | ||||
| { | ||||
| 	char *d = dst; | ||||
| 	const char *s = src; | ||||
| 	size_t n = siz; | ||||
|  | ||||
| 	/* Copy as many bytes as will fit */ | ||||
| 	if (n != 0 && --n != 0) { | ||||
| 		do { | ||||
| 			if ((*d++ = *s++) == 0) | ||||
| 	if (n != 0) { | ||||
| 		while (--n != 0) { | ||||
| 			if ((*d++ = *s++) == '\0') | ||||
| 				break; | ||||
| 		} while (--n != 0); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	/* Not enough room in dst, add NUL and traverse rest of src */ | ||||
|   | ||||
							
								
								
									
										65
									
								
								src/strnstr.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										65
									
								
								src/strnstr.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,65 @@ | ||||
| /*- | ||||
|  * Copyright (c) 2001 Mike Barcroft <mike@FreeBSD.org> | ||||
|  * Copyright (c) 1990, 1993 | ||||
|  *	The Regents of the University of California.  All rights reserved. | ||||
|  * | ||||
|  * This code is derived from software contributed to Berkeley by | ||||
|  * Chris Torek. | ||||
|  * | ||||
|  * 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. Neither the name of the University nor the names of its contributors | ||||
|  *    may be used to endorse or promote products derived from this software | ||||
|  *    without specific prior written permission. | ||||
|  * | ||||
|  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``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 REGENTS OR CONTRIBUTORS 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. | ||||
|  */ | ||||
|  | ||||
| #if defined(LIBC_SCCS) && !defined(lint) | ||||
| static char sccsid[] = "@(#)strstr.c	8.1 (Berkeley) 6/4/93"; | ||||
| #endif /* LIBC_SCCS and not lint */ | ||||
| #include <sys/cdefs.h> | ||||
| __FBSDID("$FreeBSD$"); | ||||
|  | ||||
| #include <string.h> | ||||
|  | ||||
| /* | ||||
|  * Find the first occurrence of find in s, where the search is limited to the | ||||
|  * first slen characters of s. | ||||
|  */ | ||||
| char * | ||||
| strnstr(const char *s, const char *find, size_t slen) | ||||
| { | ||||
| 	char c, sc; | ||||
| 	size_t len; | ||||
|  | ||||
| 	if ((c = *find++) != '\0') { | ||||
| 		len = strlen(find); | ||||
| 		do { | ||||
| 			do { | ||||
| 				if (slen-- < 1 || (sc = *s++) == '\0') | ||||
| 					return (NULL); | ||||
| 			} while (sc != c); | ||||
| 			if (len > slen) | ||||
| 				return (NULL); | ||||
| 		} while (strncmp(s, find, len) != 0); | ||||
| 		s--; | ||||
| 	} | ||||
| 	return ((char *)s); | ||||
| } | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user