pkgsrc/devel/libarena/Makefile

35 lines
1,001 B
Makefile
Raw Normal View History

# $NetBSD: Makefile,v 1.4 2012/10/31 11:17:10 asau Exp $
Import libarena, a BSD-licensed memory allocator abstraction API. Also included are four allocators which also serve as examples as to how to use the interface. AFAIK, it's sort of like vmem(9) in userland (not that I know much about vmem, for the manpage is quite terse, heh). I imported this not as a dependency, but because I thought it looked interesting, especially with regard to what's outlined in the last paragraph. I may use it in porting some linux audio software at some point, though that's still a ways off ... A short blurb: Libarena is a custom memory allocator interface and implementation. Four allocators are provided: flat LIFO arena allocator, object pool allocator and two malloc(3) wrappers: one which returns the pointers unadulterated and one which obeys the requested, arbitrary alignment. These can be used directly, or through their exported prototype interfaces. Libarena is meant to provide a baseline interface so allocator's can be stacked, and to provide a simple and well defined interface for libraries and applications without becoming mired in features or capabilities. It is not meant to restrict or confine what custom allocators can actually accomplish. For instance, the included pool and arena allocators include a suite of string utilities which aren't available in the generic exportable interface. Note that these string utilities are built upon a generic interface (see util.h) which can take the prototypical allocation context, so they are also available to any 3rd party compatible allocators. Surprisingly few malloc(3) library "replacements" or plug-in interfaces support a context pointer argument. They're useless for many or most of the tasks where the ability to specify an alternate malloc(3) could actually be useful, e.g. poor man's RAII. For network daemons especially this feature is useful; all allocations for a particular session can be freed simply by closing the lowest-level allocator object.
2008-02-12 03:40:37 +01:00
#
DISTNAME= libarena-${SNAPSHOT_DATE}
Import libarena, a BSD-licensed memory allocator abstraction API. Also included are four allocators which also serve as examples as to how to use the interface. AFAIK, it's sort of like vmem(9) in userland (not that I know much about vmem, for the manpage is quite terse, heh). I imported this not as a dependency, but because I thought it looked interesting, especially with regard to what's outlined in the last paragraph. I may use it in porting some linux audio software at some point, though that's still a ways off ... A short blurb: Libarena is a custom memory allocator interface and implementation. Four allocators are provided: flat LIFO arena allocator, object pool allocator and two malloc(3) wrappers: one which returns the pointers unadulterated and one which obeys the requested, arbitrary alignment. These can be used directly, or through their exported prototype interfaces. Libarena is meant to provide a baseline interface so allocator's can be stacked, and to provide a simple and well defined interface for libraries and applications without becoming mired in features or capabilities. It is not meant to restrict or confine what custom allocators can actually accomplish. For instance, the included pool and arena allocators include a suite of string utilities which aren't available in the generic exportable interface. Note that these string utilities are built upon a generic interface (see util.h) which can take the prototypical allocation context, so they are also available to any 3rd party compatible allocators. Surprisingly few malloc(3) library "replacements" or plug-in interfaces support a context pointer argument. They're useless for many or most of the tasks where the ability to specify an alternate malloc(3) could actually be useful, e.g. poor man's RAII. For network daemons especially this feature is useful; all allocations for a particular session can be freed simply by closing the lowest-level allocator object.
2008-02-12 03:40:37 +01:00
CATEGORIES= devel
MASTER_SITES= ${MASTER_SITE_LOCAL}
Import libarena, a BSD-licensed memory allocator abstraction API. Also included are four allocators which also serve as examples as to how to use the interface. AFAIK, it's sort of like vmem(9) in userland (not that I know much about vmem, for the manpage is quite terse, heh). I imported this not as a dependency, but because I thought it looked interesting, especially with regard to what's outlined in the last paragraph. I may use it in porting some linux audio software at some point, though that's still a ways off ... A short blurb: Libarena is a custom memory allocator interface and implementation. Four allocators are provided: flat LIFO arena allocator, object pool allocator and two malloc(3) wrappers: one which returns the pointers unadulterated and one which obeys the requested, arbitrary alignment. These can be used directly, or through their exported prototype interfaces. Libarena is meant to provide a baseline interface so allocator's can be stacked, and to provide a simple and well defined interface for libraries and applications without becoming mired in features or capabilities. It is not meant to restrict or confine what custom allocators can actually accomplish. For instance, the included pool and arena allocators include a suite of string utilities which aren't available in the generic exportable interface. Note that these string utilities are built upon a generic interface (see util.h) which can take the prototypical allocation context, so they are also available to any 3rd party compatible allocators. Surprisingly few malloc(3) library "replacements" or plug-in interfaces support a context pointer argument. They're useless for many or most of the tasks where the ability to specify an alternate malloc(3) could actually be useful, e.g. poor man's RAII. For network daemons especially this feature is useful; all allocations for a particular session can be freed simply by closing the lowest-level allocator object.
2008-02-12 03:40:37 +01:00
EXTRACT_SUFX= .tgz
SNAPSHOT_DATE= 20080221
Import libarena, a BSD-licensed memory allocator abstraction API. Also included are four allocators which also serve as examples as to how to use the interface. AFAIK, it's sort of like vmem(9) in userland (not that I know much about vmem, for the manpage is quite terse, heh). I imported this not as a dependency, but because I thought it looked interesting, especially with regard to what's outlined in the last paragraph. I may use it in porting some linux audio software at some point, though that's still a ways off ... A short blurb: Libarena is a custom memory allocator interface and implementation. Four allocators are provided: flat LIFO arena allocator, object pool allocator and two malloc(3) wrappers: one which returns the pointers unadulterated and one which obeys the requested, arbitrary alignment. These can be used directly, or through their exported prototype interfaces. Libarena is meant to provide a baseline interface so allocator's can be stacked, and to provide a simple and well defined interface for libraries and applications without becoming mired in features or capabilities. It is not meant to restrict or confine what custom allocators can actually accomplish. For instance, the included pool and arena allocators include a suite of string utilities which aren't available in the generic exportable interface. Note that these string utilities are built upon a generic interface (see util.h) which can take the prototypical allocation context, so they are also available to any 3rd party compatible allocators. Surprisingly few malloc(3) library "replacements" or plug-in interfaces support a context pointer argument. They're useless for many or most of the tasks where the ability to specify an alternate malloc(3) could actually be useful, e.g. poor man's RAII. For network daemons especially this feature is useful; all allocations for a particular session can be freed simply by closing the lowest-level allocator object.
2008-02-12 03:40:37 +01:00
MAINTAINER= pkgsrc-users@NetBSD.org
Import libarena, a BSD-licensed memory allocator abstraction API. Also included are four allocators which also serve as examples as to how to use the interface. AFAIK, it's sort of like vmem(9) in userland (not that I know much about vmem, for the manpage is quite terse, heh). I imported this not as a dependency, but because I thought it looked interesting, especially with regard to what's outlined in the last paragraph. I may use it in porting some linux audio software at some point, though that's still a ways off ... A short blurb: Libarena is a custom memory allocator interface and implementation. Four allocators are provided: flat LIFO arena allocator, object pool allocator and two malloc(3) wrappers: one which returns the pointers unadulterated and one which obeys the requested, arbitrary alignment. These can be used directly, or through their exported prototype interfaces. Libarena is meant to provide a baseline interface so allocator's can be stacked, and to provide a simple and well defined interface for libraries and applications without becoming mired in features or capabilities. It is not meant to restrict or confine what custom allocators can actually accomplish. For instance, the included pool and arena allocators include a suite of string utilities which aren't available in the generic exportable interface. Note that these string utilities are built upon a generic interface (see util.h) which can take the prototypical allocation context, so they are also available to any 3rd party compatible allocators. Surprisingly few malloc(3) library "replacements" or plug-in interfaces support a context pointer argument. They're useless for many or most of the tasks where the ability to specify an alternate malloc(3) could actually be useful, e.g. poor man's RAII. For network daemons especially this feature is useful; all allocations for a particular session can be freed simply by closing the lowest-level allocator object.
2008-02-12 03:40:37 +01:00
HOMEPAGE= http://www.25thandclement.com/~william/projects/libarena.html
COMMENT= Memory allocator API and implementation
BUILD_TARGET= pic
USE_FEATURES= getenv vsnprintf # XXX strsep should be added to USE_FEATURES
USE_LIBTOOL= yes
EGDIR= ${PREFIX}/share/examples/${PKGBASE}
pre-install:
${INSTALL_LIB_DIR} ${DESTDIR}${PREFIX}/lib && \
${INSTALL_DATA_DIR} ${DESTDIR}${PREFIX}/include/arena
do-install:
for fn in `eval ls ${WRKSRC}/src/*.h`; do \
${INSTALL_DATA} $$fn ${DESTDIR}${PREFIX}/include/arena; \
done
${LIBTOOL} --mode=install ${INSTALL_LIB} \
${WRKSRC}/src/${PKGBASE}.la ${DESTDIR}${PREFIX}/lib
${INSTALL_DATA_DIR} ${DESTDIR}${EGDIR} && \
${INSTALL_DATA} ${WRKSRC}/regress/stacked.c \
${DESTDIR}${EGDIR}
.include "../../mk/bsd.pkg.mk"