2016-02-26 11:24:10 +01:00
|
|
|
# $NetBSD: Makefile,v 1.41 2016/02/26 10:24:12 jperkin Exp $
|
2002-05-12 12:25:47 +02:00
|
|
|
#
|
|
|
|
|
2004-03-29 00:00:04 +02:00
|
|
|
DISTNAME= fam-2.7.0
|
2008-01-09 22:17:32 +01:00
|
|
|
PKGREVISION= 9
|
2002-05-12 12:25:47 +02:00
|
|
|
CATEGORIES= sysutils devel
|
|
|
|
MASTER_SITES= ftp://oss.sgi.com/projects/fam/download/stable/ \
|
2009-07-19 20:18:09 +02:00
|
|
|
${MASTER_SITE_GENTOO:=distfiles/}
|
2002-05-12 12:25:47 +02:00
|
|
|
|
2005-08-10 22:57:56 +02:00
|
|
|
CONFLICTS+= gamin-[0-9]*
|
|
|
|
|
2006-03-04 22:28:51 +01:00
|
|
|
MAINTAINER= pkgsrc-users@NetBSD.org
|
2002-05-12 12:25:47 +02:00
|
|
|
HOMEPAGE= http://oss.sgi.com/projects/fam/
|
|
|
|
COMMENT= File Alteration Monitor
|
2010-01-17 00:37:48 +01:00
|
|
|
LICENSE= gnu-gpl-v2 AND gnu-lgpl-v2.1 # fam and libfam
|
2002-05-12 12:25:47 +02:00
|
|
|
|
2005-05-10 01:13:33 +02:00
|
|
|
# fam is bundled with IRIX
|
|
|
|
NOT_FOR_PLATFORM= IRIX-*-*
|
|
|
|
|
2005-05-22 22:07:36 +02:00
|
|
|
USE_TOOLS+= gmake
|
2002-05-12 12:25:47 +02:00
|
|
|
USE_LIBTOOL= YES
|
|
|
|
GNU_CONFIGURE= YES
|
2004-04-04 11:24:58 +02:00
|
|
|
USE_LANGUAGES= c c++
|
2005-12-06 00:55:01 +01:00
|
|
|
CONFIGURE_ARGS+= --sysconfdir=${PKG_SYSCONFDIR:Q}
|
2002-05-12 12:25:47 +02:00
|
|
|
|
2004-02-09 19:14:45 +01:00
|
|
|
EGDIR= ${PREFIX}/share/examples/fam
|
|
|
|
CONF_FILES= ${EGDIR}/fam.conf ${PKG_SYSCONFDIR}/fam.conf
|
|
|
|
|
Add kqueue support. This way, famd can be notified of changes to files and
directories in "real time", without having to periodically poll(2) for them
after several seconds. This improves the responsiveness of applications
using famd (specially GNOME) when changes to files occur from the "outside"
(they are notified from changes immediately), or even from the application
itself (for example, have you ever tried to rename several files from
Nautilus? just a PITA).
To enable kqueue, you have to pass the 'kqueue' option to the package.
I'm not enabling it by default because it needs testing (but it should be
enabled in a future). Furthermore, I'd like to send these patches to the
FAM developers for comments too. And a review from somebody knowing kqueue
could be good! (this is the first time I use the kqueue interface, so I'm
not sure if everything is right).
A description on how this works can be found in the files/IMonKQueue.c++
file. Note that, due to FAM's design, the easiest way to do this change
is to "emulate" imon functionality.
While here, add an rc.d script for famd, in case the user prefers to run
it at system startup instead of from inetd (I created it while developing
the kqueue functionality, so it's a good moment to add it). Adjust the
MESSAGE accordingly.
Bump PKGREVISION to 4.
2004-10-17 21:20:53 +02:00
|
|
|
RCD_SCRIPTS= famd
|
|
|
|
|
2004-03-29 00:00:04 +02:00
|
|
|
SUBST_CLASSES+= paths
|
2006-04-22 11:22:05 +02:00
|
|
|
SUBST_MESSAGE.paths= Fixing hardcoded paths.
|
Add kqueue support. This way, famd can be notified of changes to files and
directories in "real time", without having to periodically poll(2) for them
after several seconds. This improves the responsiveness of applications
using famd (specially GNOME) when changes to files occur from the "outside"
(they are notified from changes immediately), or even from the application
itself (for example, have you ever tried to rename several files from
Nautilus? just a PITA).
To enable kqueue, you have to pass the 'kqueue' option to the package.
I'm not enabling it by default because it needs testing (but it should be
enabled in a future). Furthermore, I'd like to send these patches to the
FAM developers for comments too. And a review from somebody knowing kqueue
could be good! (this is the first time I use the kqueue interface, so I'm
not sure if everything is right).
A description on how this works can be found in the files/IMonKQueue.c++
file. Note that, due to FAM's design, the easiest way to do this change
is to "emulate" imon functionality.
While here, add an rc.d script for famd, in case the user prefers to run
it at system startup instead of from inetd (I created it while developing
the kqueue functionality, so it's a good moment to add it). Adjust the
MESSAGE accordingly.
Bump PKGREVISION to 4.
2004-10-17 21:20:53 +02:00
|
|
|
SUBST_STAGE.paths= pre-configure
|
2004-03-29 00:00:04 +02:00
|
|
|
SUBST_FILES.paths= man/famd.conf.5 man/famd.8
|
|
|
|
SUBST_SED.paths= -e 's,/usr/local/etc/,${PKG_SYSCONFDIR}/,g'
|
|
|
|
|
Add kqueue support. This way, famd can be notified of changes to files and
directories in "real time", without having to periodically poll(2) for them
after several seconds. This improves the responsiveness of applications
using famd (specially GNOME) when changes to files occur from the "outside"
(they are notified from changes immediately), or even from the application
itself (for example, have you ever tried to rename several files from
Nautilus? just a PITA).
To enable kqueue, you have to pass the 'kqueue' option to the package.
I'm not enabling it by default because it needs testing (but it should be
enabled in a future). Furthermore, I'd like to send these patches to the
FAM developers for comments too. And a review from somebody knowing kqueue
could be good! (this is the first time I use the kqueue interface, so I'm
not sure if everything is right).
A description on how this works can be found in the files/IMonKQueue.c++
file. Note that, due to FAM's design, the easiest way to do this change
is to "emulate" imon functionality.
While here, add an rc.d script for famd, in case the user prefers to run
it at system startup instead of from inetd (I created it while developing
the kqueue functionality, so it's a good moment to add it). Adjust the
MESSAGE accordingly.
Bump PKGREVISION to 4.
2004-10-17 21:20:53 +02:00
|
|
|
PKG_OPTIONS_VAR= PKG_OPTIONS.fam
|
|
|
|
PKG_SUPPORTED_OPTIONS= kqueue
|
|
|
|
|
|
|
|
.include "../../mk/bsd.options.mk"
|
|
|
|
|
2005-01-05 17:21:06 +01:00
|
|
|
.if !empty(PKG_OPTIONS:Mkqueue) && \
|
|
|
|
(${OPSYS} == "FreeBSD" || ${OPSYS} == "NetBSD" || ${OPSYS} == "OpenBSD")
|
Add kqueue support. This way, famd can be notified of changes to files and
directories in "real time", without having to periodically poll(2) for them
after several seconds. This improves the responsiveness of applications
using famd (specially GNOME) when changes to files occur from the "outside"
(they are notified from changes immediately), or even from the application
itself (for example, have you ever tried to rename several files from
Nautilus? just a PITA).
To enable kqueue, you have to pass the 'kqueue' option to the package.
I'm not enabling it by default because it needs testing (but it should be
enabled in a future). Furthermore, I'd like to send these patches to the
FAM developers for comments too. And a review from somebody knowing kqueue
could be good! (this is the first time I use the kqueue interface, so I'm
not sure if everything is right).
A description on how this works can be found in the files/IMonKQueue.c++
file. Note that, due to FAM's design, the easiest way to do this change
is to "emulate" imon functionality.
While here, add an rc.d script for famd, in case the user prefers to run
it at system startup instead of from inetd (I created it while developing
the kqueue functionality, so it's a good moment to add it). Adjust the
MESSAGE accordingly.
Bump PKGREVISION to 4.
2004-10-17 21:20:53 +02:00
|
|
|
CPPFLAGS+= -DHAVE_KQUEUE
|
|
|
|
|
|
|
|
SUBST_CLASSES+= kqueue
|
2006-04-22 11:22:05 +02:00
|
|
|
SUBST_MESSAGE.kqueue= Enabling kqueue monitoring.
|
Add kqueue support. This way, famd can be notified of changes to files and
directories in "real time", without having to periodically poll(2) for them
after several seconds. This improves the responsiveness of applications
using famd (specially GNOME) when changes to files occur from the "outside"
(they are notified from changes immediately), or even from the application
itself (for example, have you ever tried to rename several files from
Nautilus? just a PITA).
To enable kqueue, you have to pass the 'kqueue' option to the package.
I'm not enabling it by default because it needs testing (but it should be
enabled in a future). Furthermore, I'd like to send these patches to the
FAM developers for comments too. And a review from somebody knowing kqueue
could be good! (this is the first time I use the kqueue interface, so I'm
not sure if everything is right).
A description on how this works can be found in the files/IMonKQueue.c++
file. Note that, due to FAM's design, the easiest way to do this change
is to "emulate" imon functionality.
While here, add an rc.d script for famd, in case the user prefers to run
it at system startup instead of from inetd (I created it while developing
the kqueue functionality, so it's a good moment to add it). Adjust the
MESSAGE accordingly.
Bump PKGREVISION to 4.
2004-10-17 21:20:53 +02:00
|
|
|
SUBST_STAGE.kqueue= pre-configure
|
2004-10-17 22:12:06 +02:00
|
|
|
SUBST_FILES.kqueue= src/Makefile.in
|
|
|
|
SUBST_SED.kqueue= -e 's,@MONITOR_FUNCS@,IMonKQueue,g'
|
|
|
|
SUBST_SED.kqueue+= -e 's,@LIBS@,@LIBS@ -lpthread,g'
|
Add kqueue support. This way, famd can be notified of changes to files and
directories in "real time", without having to periodically poll(2) for them
after several seconds. This improves the responsiveness of applications
using famd (specially GNOME) when changes to files occur from the "outside"
(they are notified from changes immediately), or even from the application
itself (for example, have you ever tried to rename several files from
Nautilus? just a PITA).
To enable kqueue, you have to pass the 'kqueue' option to the package.
I'm not enabling it by default because it needs testing (but it should be
enabled in a future). Furthermore, I'd like to send these patches to the
FAM developers for comments too. And a review from somebody knowing kqueue
could be good! (this is the first time I use the kqueue interface, so I'm
not sure if everything is right).
A description on how this works can be found in the files/IMonKQueue.c++
file. Note that, due to FAM's design, the easiest way to do this change
is to "emulate" imon functionality.
While here, add an rc.d script for famd, in case the user prefers to run
it at system startup instead of from inetd (I created it while developing
the kqueue functionality, so it's a good moment to add it). Adjust the
MESSAGE accordingly.
Bump PKGREVISION to 4.
2004-10-17 21:20:53 +02:00
|
|
|
|
|
|
|
MESSAGE_SRC= ${.CURDIR}/MESSAGE ${.CURDIR}/MESSAGE.kqueue
|
|
|
|
|
|
|
|
.include "../../mk/pthread.buildlink3.mk"
|
|
|
|
.endif
|
|
|
|
|
2005-01-05 17:21:06 +01:00
|
|
|
CPPFLAGS.Darwin+= -DNDEBUG
|
2004-11-19 13:35:22 +01:00
|
|
|
LDFLAGS.SunOS+= -lsocket -lnsl
|
|
|
|
|
2016-02-26 11:24:10 +01:00
|
|
|
SUBST_CLASSES.SunOS+= sunfix
|
2006-04-22 11:22:05 +02:00
|
|
|
SUBST_MESSAGE.sunfix= Fixing ${OPSYS} namespace collision.
|
2004-11-19 13:35:22 +01:00
|
|
|
SUBST_STAGE.sunfix= pre-configure
|
|
|
|
SUBST_FILES.sunfix+= lib/Client.c++
|
|
|
|
SUBST_FILES.sunfix+= src/ClientConnection.c++ src/ClientConnection.h
|
|
|
|
SUBST_FILES.sunfix+= src/LocalClient.c++ src/LocalClient.h
|
|
|
|
SUBST_FILES.sunfix+= src/Listener.c++
|
|
|
|
SUBST_FILES.sunfix+= src/TCP_Client.h
|
|
|
|
SUBST_SED.sunfix= -e 's/sun\([^_]\)/sa_un\1/g'
|
|
|
|
|
2016-02-26 11:24:10 +01:00
|
|
|
SUBST_CLASSES.SunOS+= dirent
|
2006-04-22 11:22:05 +02:00
|
|
|
SUBST_MESSAGE.dirent= Fixing old sys/dir.h usage.
|
2004-11-19 13:35:22 +01:00
|
|
|
SUBST_STAGE.dirent= pre-configure
|
|
|
|
SUBST_FILES.dirent+= src/Directory.c++
|
|
|
|
SUBST_FILES.dirent+= src/DirectoryScanner.c++ src/DirectoryScanner.h
|
2006-10-02 23:45:05 +02:00
|
|
|
SUBST_SED.dirent= -e 's,sys/dir.h,dirent.h,g'
|
|
|
|
SUBST_SED.dirent+= -e 's/struct direct/struct dirent/g'
|
2004-11-19 13:35:22 +01:00
|
|
|
|
|
|
|
.include "../../mk/compiler.mk"
|
|
|
|
|
|
|
|
.if !empty(PKGSRC_COMPILER:Msunpro)
|
|
|
|
BUILDLINK_TRANSFORM+= rm:-lstdc++
|
|
|
|
.endif
|
|
|
|
|
Add kqueue support. This way, famd can be notified of changes to files and
directories in "real time", without having to periodically poll(2) for them
after several seconds. This improves the responsiveness of applications
using famd (specially GNOME) when changes to files occur from the "outside"
(they are notified from changes immediately), or even from the application
itself (for example, have you ever tried to rename several files from
Nautilus? just a PITA).
To enable kqueue, you have to pass the 'kqueue' option to the package.
I'm not enabling it by default because it needs testing (but it should be
enabled in a future). Furthermore, I'd like to send these patches to the
FAM developers for comments too. And a review from somebody knowing kqueue
could be good! (this is the first time I use the kqueue interface, so I'm
not sure if everything is right).
A description on how this works can be found in the files/IMonKQueue.c++
file. Note that, due to FAM's design, the easiest way to do this change
is to "emulate" imon functionality.
While here, add an rc.d script for famd, in case the user prefers to run
it at system startup instead of from inetd (I created it while developing
the kqueue functionality, so it's a good moment to add it). Adjust the
MESSAGE accordingly.
Bump PKGREVISION to 4.
2004-10-17 21:20:53 +02:00
|
|
|
post-extract:
|
|
|
|
${CP} ${FILESDIR}/IMonKQueue.c++ ${WRKSRC}/src
|
|
|
|
${CP} ${FILESDIR}/imon-compat.h ${WRKSRC}/src
|
|
|
|
|
2002-05-12 12:25:47 +02:00
|
|
|
.include "../../mk/bsd.pkg.mk"
|