pkgsrc/pkgtools/libnbcompat/files
rillig 0c496b4733 pkgtools/libnbcompat: fix regular expression literals in AWK program
gawk: nbcompat.awk:5: warning:
regexp escape sequence `\#' is not a known regexp operator
2019-09-13 20:23:50 +00:00
..
db
nbcompat Use the correct prototype - thanks <gutteridge> 2019-07-09 09:43:32 +00:00
private
__fts13.c Add SCO OpenServer 5.0.7/3.2 support 2014-03-14 22:08:17 +00:00
__glob13.c PR/52982: Eitan Adler: fix incorrect bounds computation. 2019-02-20 14:44:24 +00:00
__unsetenv13.c
aclocal.m4
asprintf.c
config.guess
config.sub Same netbsd*-eabi* tweak for libnbcompat's even older config.sub. 2015-02-14 07:25:54 +00:00
configure Include strnlen(3) - Needed on Tiger and more recent Intel only Darwin releases. 2019-07-08 20:34:54 +00:00
configure.ac Include strnlen(3) - Needed on Tiger and more recent Intel only Darwin releases. 2019-07-08 20:34:54 +00:00
engine.c
err.c
fgetln.c
findenv.c
fnmatch.c
fparseln.c
fts.c
getaddrinfo.c
getdelim.c Avoid duplicated RCS IDs forcing permanent rebuilds. 2015-12-25 20:12:46 +00:00
getenv.c
getline.c Avoid duplicated RCS IDs forcing permanent rebuilds. 2015-12-25 20:12:46 +00:00
getopt.c
getopt_long.c
gettemp.c
glob.c
install-sh
isblank.c
lchflags.c
lchmod.c
lchown.c
lutimes.c
Makefile.in Reapply 1.37, but split the dependencies correctly into the header and 2015-05-02 12:52:59 +00:00
md5c.c As the seemingly untested -Werror changes break the bootstrap at least 2015-06-08 00:44:46 +00:00
md5hl.c
mdXhl.c
mkdtemp.c
mkstemp.c
nbcompat.awk pkgtools/libnbcompat: fix regular expression literals in AWK program 2019-09-13 20:23:50 +00:00
nbcompat.h
poll.c
pwcache.c
README Include strnlen(3) - Needed on Tiger and more recent Intel only Darwin releases. 2019-07-08 20:34:54 +00:00
regcomp.c
regerror.c
regexec.c
regfree.c
rmd160.c As the seemingly untested -Werror changes break the bootstrap at least 2015-06-08 00:44:46 +00:00
rmd160hl.c
setenv.c
setgroupent.c
setmode.c
setpassent.c
setprogname.c
sha1.c
sha1hl.c
sha2.c
sha2hl.c
shquote.c
snprintf.c
src2nbcompat Remove clauses 3,4 from TNF-only copyright blocks. 2018-08-22 20:48:36 +00:00
statvfs.c
strdup.c
strerror.c
strlcat.c
strlcpy.c
strmode.c
strnlen.c Include strnlen(3) - Needed on Tiger and more recent Intel only Darwin releases. 2019-07-08 20:34:54 +00:00
strsep.c
strtoll.c
timegm.c
unsetenv.c
unvis.c Make __nbcompat_unvis13 static, it is not part of the interface 2015-09-03 09:05:54 +00:00
usleep.c
utimes.c
vis.c
warn.c

$NetBSD: README,v 1.24 2019/07/08 20:34:54 sevan Exp $

 0 Introduction
 ==============

libnbcompat builds and installs a portable NetBSD-compatibility library
that supplies routines missing on operating systems that are used by
the family of pkgsrc bootstrap tools.  Note that libnbcompat is very
much a work-in-progress.  Only the functions that are directly used
by the bootstrap tools are implemented in the library.  At the moment,
this includes the following packages:

	archivers/pax
	pkgtools/mtree
	pkgtools/pkg_install
	textproc/nbsed

A script, src2nbcompat, is also included in the sources that simplifies
importing software from the NetBSD src module into pkgsrc.


 1 Updating this package
 =======================

Please take care when updating this package.  Do *not* simply commit
changes to this package and ask for testers.  This package is too
fundamental to the proper bootstrapping of pkgsrc to let accidental
breakage seep in.  Proper methodology for updating this package is:

    (1) Post a tarball at a publicly accessible URL containing the
	pkgtools/libnbcompat directory.

    (2) Ask on the tech-pkg@NetBSD.org mailing list for testers.

    (3) Fix any breakage on non-NetBSD operating systems before
	committing.


 2 Tested operating systems
 ==========================

*NOTE*
*NOTE* This section should be kept up-to-date with the results for
*NOTE* the most recent libnbcompat.
*NOTE*

libnbcompat-20040911 has been tested to build and install correctly
on the following operating systems:

	FreeBSD-4.8/i386		<jlam@NetBSD.org>
	NetBSD-1.6.2/i386		<jlam@NetBSD.org>
	Solaris 9/sparc			<salo@NetBSD.org>

libnbcompat-20041024 has been tested to build and install correctly
on the following operating systems:

	FreeBSD-4.11/i386		<jschauma@NetBSD.org>
	FreeBSD-6.1/amd64		<jschauma@NetBSD.org>
	Darwin-8.3/powerpc		<schwarz@NetBSD.org>
	IRIX-5.3/mipseb			<schwarz@NetBSD.org>
	IRIX-6.5/mipseb			<jschauma@NetBSD.org>
	Linux/i386			<schwarz@NetBSD.org>
	RHEL4 Linux 2.6/i386		<jschauma@NetBSD.org>
	Tru64 UNIX 5.1B-2/alpha		<rodent@NetBSD.org>

libnbcompat-20070507 has been tested to build and install correctly
on the following operating systems:

	-

libnbcompat-20070531 has been tested to build and install correctly
on the following operating systems:

	SunOS-5.10-sparc		<rillig@NetBSD.org>
	NetBSD-3.0-i386			<rillig@NetBSD.org>
	IRIX-6.5-mips			<rillig@NetBSD.org>

libnbcompat-20070721 has been tested to build and install correctly
on the following operating systems:

	HPUX-11.11-hppa			<tnn@NetBSD.org>
	Interix-3.5-i586		<tnn@NetBSD.org>

libnbcompat-20130908 has been tested to build and install correctly
on the following operating systems:

	Debian GNU/kFreeBSD/amd64 7.1	<ryoon@NetBSD.org>
	Sun Solaris/amd64 10u8		<ryoon@NetBSD.org>
	NetBSD/amd64 6.99.23		<ryoon@NetBSD.org>
	FreeBSD/amd64 9.1		<ryoon@NetBSD.org>
	OpenBSD/amd64 5.3		<ryoon@NetBSD.org>
	DragonFly/amd64 3.4.1		<ryoon@NetBSD.org>
	Debian GNU/Linux/amd64 7.1	<ryoon@NetBSD.org>
	CentOS Linux/amd64 6.5		<rodent@NetBSD.org>
	OpenBSD/sparc64 5.5		<rodent@NetBSD.org>

libnbcompat-20140725 has been tested to build and install correctly
on the following operating systems:

	Ubuntu GNU/Linux/amd64 12.04	<jperkin@joyent.com>
	CentOS Linux/amd64 6.5		<rodent@NetBSD.org>
	CentOS Linux/amd64 6.6		<rodent@NetBSD.org>
	CentOS Linux/amd64 7.0		<rodent@NetBSD.org>
	OpenBSD/sparc64 5.5		<rodent@NetBSD.org>
	OpenBSD/sparc64 5.6		<rodent@NetBSD.org>
	FreeBSD/amd64 10.1		<rodent@NetBSD.org>

libnbcompat-20150419 has been tested to build and install correctly
on the following operating systems:

	NetBSD/i386 5.2.3		<tnn@NetBSD.org>
	HP-UX/hppa 11.11		<tnn@NetBSD.org>
	
libnbcompat-20190608 has been tested to build and install correctly
on the following operating systems:

	NetBSD/amd64 8.99.49		<sevan@NetBSD.org>
	Darwin/powerpc 8.11.0		<sevan@NetBSD.org>
	FreeBSD/amd64 13-CURRENT	<sevan@NetBSD.org>

 3 Usage
 =======

This library is intended to simplify porting NetBSD software.  To that
end, the changes to NetBSD sources to use libnbcompat are minor.  The
procedure is:

    (1) Add #include <nbcompat.h> at the top of the source files that
	include system headers, but below the inclusion of any
	"config.h".

    (2) Surround each system header file included in the source file
	with #if HAVE_<header_name>_H ... #endif.

You may need to add additional headers present on other operating
systems that define any system-supplied functions, e.g. <sys/vfs.h>.

The src2nbcompat script included in the libncompat sources can be used
to automate this process to some extent.  It is intended to import
sources from a NetBSD src checkout into pkgsrc.  It will copy the
sources from a directory and automatically insert the proper lines
into the files.  For example, to import the pkg_install sources into
pkgsrc, run:

	src2nbcompat \
		/usr/src/usr.sbin/pkg_install \
		/usr/pkgsrc/pkgtools/pkg_install/files

You will need to run a "cvs diff" on the imported files to check that
any local changes are preserved across imports.