Re: Bug#697032: rcpp: FTBFS[kfreebsd]: #error "Rcpp::Timer not supported by your OS."
- To: Steven Chamberlain <steven@pyro.eu.org>
- Cc: Dirk Eddelbuettel <edd@debian.org>, Rainer Hurling <rhurlin@gwdg.de>,	Christoph Egger <christoph@debian.org>, debian-bsd@lists.debian.org,	697032@bugs.debian.org
- Subject: Re: Bug#697032: rcpp: FTBFS[kfreebsd]: #error "Rcpp::Timer not supported by your OS."
- From: Guillem Jover <guillem@debian.org>
- Date: Fri, 11 Jan 2013 00:31:39 +0100
- Message-id: <[🔎] 20130110233139.GA27428@gaara.hadrons.org>
- Mail-followup-to: Steven Chamberlain <steven@pyro.eu.org>,	Dirk Eddelbuettel <edd@debian.org>,	Rainer Hurling <rhurlin@gwdg.de>,	Christoph Egger <christoph@debian.org>, debian-bsd@lists.debian.org,	697032@bugs.debian.org
- In-reply-to: <50E1CE60.1080007@pyro.eu.org>
- References: <87k3rzhyaq.fsf@mitoraj.siccegge.de> <20704.56660.249233.434055@max.nulle.part> <878v8fhurd.fsf@mitoraj.siccegge.de> <20704.62255.105601.290906@max.nulle.part> <50E0F966.7050600@pyro.eu.org> <50E13516.3060206@gwdg.de> <50E1BEF1.9010402@pyro.eu.org> <20705.50686.100568.628609@max.nulle.part> <50E1CE60.1080007@pyro.eu.org>
On Mon, 2012-12-31 at 17:41:52 +0000, Steven Chamberlain wrote:
> On 31/12/12 17:06, Dirk Eddelbuettel wrote:
> > https://r-forge.r-project.org/scm/viewvc.php/pkg/Rcpp/src/Timer.cpp?root=rcpp&r1=4182&r2=4181&pathrev=4182
> 
> Actually... presence of <time.h> rather depends on the libc, not the kernel?
> 
> So __GLIBC__ is perhaps more relevant than __FreeBSD_kernel__ in this
> case - plus it should work for other GNU/k*BSD variants if/when they exist.
Well, that's still suboptimal, the ideal solution in this kind of
cases is to test for the feature at build time, which avoids all this
ifdef whitelists, and subsequent updates.
> While here, I think I can explain the build failure on GNU/Hurd.  The
> test for __MACH__ applies to both Apple systems and GNU systems.  I
> suggest using mach/mach_time.h only for __APPLE__, and then adding
> __GNU__ to the list for time.h
For Mac OS X I'd test for __APPLE__ && __MACH__, otherwise that could
trigger on other non Mach-based Apple systems.
Thanks,
Guillem
Reply to: