pkgsrc/pkgtools/libnbcompat/files
2007-07-31 13:17:33 +00:00
..
nbcompat Don't use u_{char,short,int,long} as they are non-standard. 2007-07-31 13:17:33 +00:00
private
__fts13.c Don't use u_{char,short,int,long} as they are non-standard. 2007-07-31 13:17:33 +00:00
__glob13.c Don't use u_{char,short,int,long} as they are non-standard. 2007-07-31 13:17:33 +00:00
__unsetenv13.c
aclocal.m4
asprintf.c Fix logic error in buffer handling (Hi Joerg!) 2007-07-20 00:10:06 +00:00
bits.c
config.guess Sync config.{guess,sub} with mk/gnu-configure. 2007-03-12 00:48:28 +00:00
config.sub Sync config.{guess,sub} with mk/gnu-configure. 2007-03-12 00:48:28 +00:00
configure * configure.ac: Add AC_TYPE_UINTPTR_T, needed by sha2.c. 2007-07-21 13:57:33 +00:00
configure.ac * configure.ac: Add AC_TYPE_UINTPTR_T, needed by sha2.c. 2007-07-21 13:57:33 +00:00
engine.c
err.c
fgetln.c Updated libnbcompat to 20070531. 2007-05-31 10:18:49 +00:00
findenv.c
fnmatch.c
fparseln.c
fts.c
getenv.c
getopt_long.c
gettemp.c Don't use u_{char,short,int,long} as they are non-standard. 2007-07-31 13:17:33 +00:00
glob.c
install-sh
isblank.c
lchflags.c Don't use u_{char,short,int,long} as they are non-standard. 2007-07-31 13:17:33 +00:00
lchmod.c
lchown.c
lutimes.c
Makefile.in Add SHA256/SHA384/SHA512 to libnbcompat. Update version to 20070507. 2007-05-07 16:38:47 +00:00
malloc.c
md5c.c
md5hl.c
mdXhl.c
mkdtemp.c
mkstemp.c
nbcompat.awk
nbcompat.h
poll.c
pwcache.c Don't use u_{char,short,int,long} as they are non-standard. 2007-07-31 13:17:33 +00:00
README Another version bump due to added configure check for uintptr_t 2007-07-21 14:39:25 +00:00
regcomp.c
regerror.c
regexec.c
regfree.c
rmd160.c Don't use u_{char,short,int,long} as they are non-standard. 2007-07-31 13:17:33 +00:00
rmd160hl.c Don't use u_{char,short,int,long} as they are non-standard. 2007-07-31 13:17:33 +00:00
setenv.c
setgroupent.c
setmode.c Don't use u_{char,short,int,long} as they are non-standard. 2007-07-31 13:17:33 +00:00
setpassent.c
setprogname.c
sha1.c Don't use u_{char,short,int,long} as they are non-standard. 2007-07-31 13:17:33 +00:00
sha1hl.c Don't use u_{char,short,int,long} as they are non-standard. 2007-07-31 13:17:33 +00:00
sha2.c Fix SHA256/SHA512 to work on strict alignment platforms. This was 2007-07-18 14:09:55 +00:00
sha2hl.c Don't use u_{char,short,int,long} as they are non-standard. 2007-07-31 13:17:33 +00:00
snprintf.c Handle trailing NUL correctly. 2007-07-20 00:11:25 +00:00
src2nbcompat Obfuscate embedded $NetBSD$ strings a bit, so that pkgsrc doesn't pick 2007-06-19 00:45:13 +00:00
statvfs.c
strdup.c
strerror.c
strlcat.c
strlcpy.c
strmode.c
strsep.c
strtoll.c
unsetenv.c
unvis.c Don't use u_{char,short,int,long} as they are non-standard. 2007-07-31 13:17:33 +00:00
usleep.c
utimes.c
vis.c Don't use u_{char,short,int,long} as they are non-standard. 2007-07-31 13:17:33 +00:00
warn.c

$NetBSD: README,v 1.18 2007/07/21 14:39:25 tnn 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>

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

	DragonFly-1.8/i386		<joerg@NetBSD.org>

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>

 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.