public inbox for gentoo-commits@lists.gentoo.org
 help / color / mirror / Atom feed
From: "Justin Lecher" <jlec@gentoo.org>
To: gentoo-commits@lists.gentoo.org
Subject: [gentoo-commits] proj/sci:master commit in: dev-cpp/eigen/
Date: Sat, 18 Jan 2014 07:39:24 +0000 (UTC)	[thread overview]
Message-ID: <1389901652.07dc255d12d136afb211c004c983ba0aa922401a.jlec@gentoo> (raw)

commit:     07dc255d12d136afb211c004c983ba0aa922401a
Author:     Justin Lecher <jlec <AT> gentoo <DOT> org>
AuthorDate: Thu Jan 16 19:47:32 2014 +0000
Commit:     Justin Lecher <jlec <AT> gentoo <DOT> org>
CommitDate: Thu Jan 16 19:47:32 2014 +0000
URL:        http://git.overlays.gentoo.org/gitweb/?p=proj/sci.git;a=commit;h=07dc255d

dev-cpp/eigen: Backport cmake fix

Package-Manager: portage-2.2.8

---
 dev-cpp/eigen/ChangeLog             |   8 ++-
 dev-cpp/eigen/eigen-3.2.0-r1.ebuild | 102 ++++++++++++++++++++++++++++++++++++
 dev-cpp/eigen/metadata.xml          |  14 ++---
 3 files changed, 116 insertions(+), 8 deletions(-)

diff --git a/dev-cpp/eigen/ChangeLog b/dev-cpp/eigen/ChangeLog
index 521bc49..fc51326 100644
--- a/dev-cpp/eigen/ChangeLog
+++ b/dev-cpp/eigen/ChangeLog
@@ -1,7 +1,13 @@
 # ChangeLog for dev-cpp/eigen
-# Copyright 1999-2013 Gentoo Foundation; Distributed under the GPL v2
+# Copyright 1999-2014 Gentoo Foundation; Distributed under the GPL v2
 # $Header: /var/cvsroot/gentoo-x86/dev-cpp/eigen/ChangeLog,v 1.44 2011/03/25 16:01:28 jlec Exp $
 
+*eigen-3.2.0-r1 (16 Jan 2014)
+
+  16 Jan 2014; Justin Lecher <jlec@gentoo.org> +eigen-3.2.0-r1.ebuild,
+  metadata.xml:
+  Backport cmake fix
+
   20 Oct 2013; Honza Macháček <Hloupy.Honza@centrum.cz> eigen-9999.ebuild:
   Avoid creating TeX fonts out of the sandbox.
 

diff --git a/dev-cpp/eigen/eigen-3.2.0-r1.ebuild b/dev-cpp/eigen/eigen-3.2.0-r1.ebuild
new file mode 100644
index 0000000..13eb0f0
--- /dev/null
+++ b/dev-cpp/eigen/eigen-3.2.0-r1.ebuild
@@ -0,0 +1,102 @@
+# Copyright 1999-2014 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: $
+
+EAPI=5
+
+FORTRAN_NEEDED=fortran
+
+if [[ ${PV} == "9999" ]] ; then
+	_SCM=mercurial
+	EHG_REPO_URI="https://bitbucket.org/eigen/eigen"
+	SRC_URI=""
+	KEYWORDS=""
+else
+	SRC_URI="
+		http://bitbucket.org/eigen/eigen/get/${PV}.tar.bz2 -> ${P}.tar.bz2
+		https://bitbucket.org/eigen/eigen/commits/1d71b1341c03a7c485289be2c8bd906a259c0487/raw/ -> ${P}-cmake.patch
+		"
+	KEYWORDS="~amd64 ~x86 ~amd64-linux ~x86-linux"
+fi
+
+inherit alternatives-2 cmake-utils fortran-2 multilib vcs-snapshot ${_SCM}
+
+DESCRIPTION="C++ template library for linear algebra"
+HOMEPAGE="http://eigen.tuxfamily.org/"
+
+SLOT="3"
+LICENSE="MPL-2.0"
+IUSE="adolc doc fortran fftw gmp mkl sparse static-libs test"
+
+# TODO: support for pastix
+CDEPEND="
+	adolc? ( sci-libs/adolc[sparse?] )
+	fftw? ( >=sci-libs/fftw-3 )
+	gmp? ( dev-libs/gmp dev-libs/mpfr )
+	mkl? ( sci-libs/mkl )
+	sparse? (
+		dev-cpp/sparsehash
+		sci-libs/cholmod[metis]
+		sci-libs/superlu
+		sci-libs/umfpack )"
+DEPEND="
+	doc? ( app-doc/doxygen[dot,latex] )
+	test? ( ${CDEPEND} )"
+
+RDEPEND="
+	!dev-cpp/eigen:0
+	${CDEPEND}"
+
+PATCHES=(
+	"${DISTDIR}"/${P}-cmake.patch
+	)
+
+src_configure() {
+	# TOFIX: static-libs for blas are always built with PIC
+	# TOFIX: is it worth fixing all the automagic given no library is built?
+	local mycmakeargs=(
+		-DEIGEN_BUILD_BTL=OFF
+		-DEIGEN_TEST_NO_OPENGL=ON
+		$(cmake-utils_use test EIGEN_BUILD_TESTS)
+		$(cmake-utils_use !fortran EIGEN_TEST_NO_FORTRAN)
+	)
+	export VARTEXFONTS="${T}/fonts"
+	CMAKE_BUILD_TYPE="release" cmake-utils_src_configure
+	# lapack not ready yet?
+	use fortran && FORTRAN_LIBS="blas"
+}
+
+src_compile() {
+	local targets="${FORTRAN_LIBS}"
+	use doc && targets+=" doc"
+	use test && targets+=" buildtests"
+	cmake-utils_src_compile ${targets}
+}
+
+src_install() {
+	cmake-utils_src_install
+	use doc && dohtml -r "${CMAKE_BUILD_DIR}"/doc/html/*
+	local x
+	for x in ${FORTRAN_LIBS}; do
+		local libname="eigen_${x}"
+		cd "${CMAKE_BUILD_DIR}"/${x}
+		dolib.so lib${libname}.so
+		use static-libs && newlib.a lib${libname}_static.a lib${libname}.a
+		cat > ${libname}.pc <<-EOF
+			prefix=${EPREFIX}/usr
+			libdir=\${prefix}/$(get_libdir)
+			includedir=\${prefix}/include
+			Name: ${PN}
+			Description: ${DESCRIPTION} ${x^^} implementation
+			Version: ${PV}
+			URL: ${HOMEPAGE}
+			Libs: -L\${libdir} -l${libname}
+			Libs.private: -lm
+			$([[ ${x} == lapack ]] && echo "Requires: blas")
+		EOF
+		alternatives_for ${x} eigen 0 \
+			/usr/$(get_libdir)/pkgconfig/${x}.pc ${libname}.pc
+		insinto /usr/$(get_libdir)/pkgconfig
+		doins ${libname}.pc
+	done
+}

diff --git a/dev-cpp/eigen/metadata.xml b/dev-cpp/eigen/metadata.xml
index a4a9327..a7abef9 100644
--- a/dev-cpp/eigen/metadata.xml
+++ b/dev-cpp/eigen/metadata.xml
@@ -1,23 +1,23 @@
 <?xml version="1.0" encoding="UTF-8"?>
 <!DOCTYPE pkgmetadata SYSTEM "http://www.gentoo.org/dtd/metadata.dtd">
 <pkgmetadata>
-<herd>sci</herd>
-<longdescription lang="en">
+  <herd>sci</herd>
+  <longdescription lang="en">
   Eigen is a lightweight C++ template library for vector and matrix math,
   a.k.a. linear algebra. Unlike most other linear algebra libraries, Eigen
   focuses on the simple mathematical needs of applications: games and other
   OpenGL apps, spreadsheets and other office apps, etc. Eigen is dedicated to
   providing optimal speed with GCC.
 </longdescription>
-<use>
-  <flag name="adolc">
+  <use>
+    <flag name="adolc">
     Enable use for automatic differentiation using <pkg>sci-libs/adolc</pkg>
   </flag>
-  <flag name="mkl">
+    <flag name="mkl">
     Use propertary intel blas/lapack implementation through <pkg>sci-libs/mkl</pkg>
   </flag>
-  <flag name="sparse">
+    <flag name="sparse">
     Enable use for extra sparse matrix with <pkg>sci-libs/umfpack</pkg>, <pkg>sci-libs/cholmod</pkg>, <pkg>sci-libs/superlu</pkg> and <pkg>dev-cpp/sparsehash</pkg>
   </flag>
-</use>
+  </use>
 </pkgmetadata>


             reply	other threads:[~2014-01-18  7:39 UTC|newest]

Thread overview: 36+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2014-01-18  7:39 Justin Lecher [this message]
  -- strict thread matches above, loose matches on Subject: below --
2019-11-25  5:43 [gentoo-commits] proj/sci:master commit in: dev-cpp/eigen/ Benda XU
2017-05-13 15:56 Justin Lecher
2016-02-24 18:31 Justin Lecher
2016-02-22 13:25 Justin Lecher
2016-02-20 15:40 Justin Lecher
2015-12-24  8:55 Justin Lecher
2015-12-04 17:33 Marius Brehler
2015-12-04  7:01 Justin Lecher
2015-11-30 10:58 Justin Lecher
2014-10-17 22:47 Jauhien Piatlicki
2014-09-16  0:27 Christoph Junghans
2014-09-12  9:03 Jauhien Piatlicki
2014-04-24 23:09 Sebastien Fabbro
2014-04-24 23:09 Sebastien Fabbro
2014-04-22 20:47 Sebastien Fabbro
2014-01-18  7:38 Justin Lecher
2013-10-20 10:35 Honza Macháček
2013-08-07 21:34 Sebastien Fabbro
2013-04-29 16:32 Sebastien Fabbro
2012-12-13  0:10 Sebastien Fabbro
2012-11-19 19:11 Sebastien Fabbro
2012-10-25 15:54 Justin Lecher
2012-07-26 21:07 Sebastien Fabbro
2012-07-09 23:48 Sebastien Fabbro
2012-07-09 20:57 Sebastien Fabbro
2012-06-29  0:27 Sebastien Fabbro
2012-03-25  1:36 Andrea Arteaga
2012-02-10 21:39 Andrea Arteaga
2011-12-20 18:00 Sebastien Fabbro
2011-10-07 10:53 Andrea Arteaga
2011-08-29 14:49 Justin Lecher
2011-08-29 13:52 Andrea Arteaga
2011-08-19 15:29 Andrea Arteaga
2011-08-19  0:29 Andrea Arteaga
2011-08-19  0:25 Andrea Arteaga

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1389901652.07dc255d12d136afb211c004c983ba0aa922401a.jlec@gentoo \
    --to=jlec@gentoo.org \
    --cc=gentoo-commits@lists.gentoo.org \
    --cc=gentoo-dev@lists.gentoo.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox