commit:     ff441371867ec3d794b1b3133c7a4dabd59907f4
Author:     Göktürk Yüksek <gokturk <AT> gentoo <DOT> org>
AuthorDate: Wed Aug 16 02:49:52 2017 +0000
Commit:     Göktürk Yüksek <gokturk <AT> gentoo <DOT> org>
CommitDate: Wed Aug 16 02:52:22 2017 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=ff441371

app-forensics/sleuthkit: bump to 4.4.2, add use flags for doc, java, zlib, test

The java USE flag is package.use.mask'ed on PPC and HPPA as java isn't
available on those arches.

Package-Manager: Portage-2.3.5, Repoman-2.3.2

 app-forensics/sleuthkit/Manifest                   |   2 +
 .../sleuthkit/files/sleuthkit-4.4.2-c89-fix.patch  |  29 ++++
 app-forensics/sleuthkit/sleuthkit-4.4.2.ebuild     | 173 +++++++++++++++++++++
 profiles/arch/hppa/package.use.mask                |   4 +
 profiles/arch/powerpc/package.use.mask             |   4 +
 5 files changed, 212 insertions(+)

diff --git a/app-forensics/sleuthkit/Manifest b/app-forensics/sleuthkit/Manifest
index b0cdb7fdef3..07718f8cb3d 100644
--- a/app-forensics/sleuthkit/Manifest
+++ b/app-forensics/sleuthkit/Manifest
@@ -2,3 +2,5 @@ DIST sleuthkit-4.0.2.tar.gz 7577570 SHA256 
112f80fbc6a868c18c7a924f756b35c79eed9
 DIST sleuthkit-4.1.0.tar.gz 7974564 SHA256 
b410428df2e1b253fa23ce6a299d059d8c2650bf9c602f7b80c0f4ce1368c36a SHA512 
1cfa96bd3746c59c92c3e3f07f5f3f0f6896239bcaec012c43958654bb63794ecf9d7bd28bb9b4ab939558f4b27f03cd87f645ea91a8f9cfbb9037df93ef5223
 WHIRLPOOL 
20856982b77ecbdd1ed3b7c147e4340461830f0238ba7cdc17da3159f5a666df5b3d490760699d25d2896289c811f615ffb4160d163f9917f09e57a37ff26a21
 DIST sleuthkit-4.1.2.tar.gz 7990136 SHA256 
58253b35c016083558fb581308f4a3baf884229de89eb84ddbfb977ed56600d3 SHA512 
1f64acf42e86adf275bcd86c63c097210a498ac34ce69e64b3c120d86dffae65b5d57ed9618692dd510f637e940a48a60912dd57c8de840bf3a2b4428baabab8
 WHIRLPOOL 
1298a345416bec11564007c41474010cbddc26289aee025f31ecd2b7069f0d16ca81eeb07a292e38d91d6b34c3a891fad8a2f4b42bfd4df96053469d25dc8c65
 DIST sleuthkit-4.1.3.tar.gz 7952733 SHA256 
67f9d2a31a8884d58698d6122fc1a1bfa9bf238582bde2b49228ec9b899f0327 SHA512 
66f6ac32da5a21b3505390557ed6cf7bbcfcca69f231e20a7086fd48c5de45a3f064a716837d25eb582d0a89bae3b6ba7e89dcf3159e1cacdb4b5d452d0ce9a2
 WHIRLPOOL 
34d59163812d5e2b135d6d3a05bc9bed2f2739ab47bd77ed25ee3162eaf7389fec40a7b187745ef65b9596877399884d3081f2f4549fc0c4390382ec247174bc
+DIST sleuthkit-4.4.2.tar.gz 8572974 SHA256 
135964463f4b0a58fcd95fdf731881fcd6f2f227eeb8ffac004880c8e4d8dd53 SHA512 
970704c0e650b54df49d92f7a5c82d1c8cd37f589bf1a90ba5df6b3cd26a4e3676fbbbf58a176eeb002cdefbd33fb1fc057b11256b4a3cf1b8f782beb618a1de
 WHIRLPOOL 
8f68e2360d8ad82912898f7e07c4620183f4e19a40b5193966815dca7efa139cf00802d54303164e9c2a5364e5af3bfe4da937869deb615760fb70fba4ddce87
+DIST sqlite-jdbc-3.8.11.jar 5131732 SHA256 
0e36f2ec132dd67ecaeecc98bb17e5c215a077991e2a068a490d954b1bf2de8d SHA512 
5f4705101992e8916e29742c560aef0d01eba9dc0d2d984b75a77e56be3c9fd20b284390fe8f9bb54bf9d1f8528c3413922684c446212ca8961ac731543fb179
 WHIRLPOOL 
e8e34e10821e308dbd16cfecf1a332a60d8b34067f48fdc8adebc07fd1cb578a1f921fe57db4ac02d4fe11699a6a96a06543817027fe173852fda8ff3d625cce

diff --git a/app-forensics/sleuthkit/files/sleuthkit-4.4.2-c89-fix.patch 
b/app-forensics/sleuthkit/files/sleuthkit-4.4.2-c89-fix.patch
new file mode 100644
index 00000000000..5d4f91e98b9
--- /dev/null
+++ b/app-forensics/sleuthkit/files/sleuthkit-4.4.2-c89-fix.patch
@@ -0,0 +1,29 @@
+From 7caca2f8be471be337f7aea70cd900164bf070eb Mon Sep 17 00:00:00 2001
+From: Gokturk Yuksek <[email protected]>
+Date: Tue, 15 Aug 2017 21:04:24 -0400
+Subject: [PATCH] tsk/img/aff: loop initial declarations are not allowed in C89
+
+Declaring an integer inside a for loop as in for(int i;;) is not
+allowed in C89 and causes a build failure. Fix it by declaring the
+variable just before the for loop.
+---
+ tsk/img/aff.c | 3 ++-
+ 1 file changed, 2 insertions(+), 1 deletion(-)
+
+diff --git a/tsk/img/aff.c b/tsk/img/aff.c
+index fd9c4ff..a832bfb 100644
+--- a/tsk/img/aff.c
++++ b/tsk/img/aff.c
+@@ -216,7 +216,8 @@ aff_close(TSK_IMG_INFO * img_info)
+ {
+     IMG_AFF_INFO *aff_info = (IMG_AFF_INFO *) img_info;
+     af_close(aff_info->af_file);
+-      for (int i = 0; i < img_info->num_img; i++) {
++      int i;
++      for (i = 0; i < img_info->num_img; i++) {
+               if (img_info->images[i])
+                       free(img_info->images[i]);
+       }
+-- 
+2.10.2
+

diff --git a/app-forensics/sleuthkit/sleuthkit-4.4.2.ebuild 
b/app-forensics/sleuthkit/sleuthkit-4.4.2.ebuild
new file mode 100644
index 00000000000..754294c9377
--- /dev/null
+++ b/app-forensics/sleuthkit/sleuthkit-4.4.2.ebuild
@@ -0,0 +1,173 @@
+# Copyright 1999-2017 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=6
+
+JAVA_PKG_BSFIX_NAME="build.xml build-unix.xml"
+inherit autotools java-pkg-opt-2 java-ant-2
+
+DESCRIPTION="A collection of file system and media management forensic 
analysis tools"
+HOMEPAGE="https://www.sleuthkit.org/sleuthkit/";
+# TODO: sqlite-jdbc does not exist in the tree, we bundle it for now
+SRC_URI="https://github.com/${PN}/${PN}/releases/download/${P}/${P}.tar.gz
+       java? ( 
http://repo1.maven.org/maven2/org/xerial/sqlite-jdbc/3.8.11/sqlite-jdbc-3.8.11.jar
 )"
+
+LICENSE="CPL-1.0 GPL-2+ IBM java? ( Apache-2.0 )"
+SLOT="0/13" # subslot = major soname version
+KEYWORDS="~amd64 ~hppa ~ppc ~x86"
+IUSE="aff doc ewf java static-libs test +threads zlib"
+
+DEPEND="
+       dev-db/sqlite:3
+       dev-lang/perl:*
+       aff? ( app-forensics/afflib )
+       ewf? ( app-forensics/libewf:= )
+       java? (
+               >=virtual/jdk-1.8:*
+               >=dev-java/c3p0-0.9.5:0
+               >=dev-java/jdbc-postgresql-9.4:0
+       )
+       zlib? ( sys-libs/zlib )
+"
+RDEPEND="${DEPEND}
+       java? ( >=virtual/jre-1.8:= )
+"
+DEPEND="${DEPEND}
+       doc? ( app-doc/doxygen )
+       test? ( >=dev-util/cppunit-1.2.1 )
+"
+
+PATCHES=(
+       "${FILESDIR}"/${PN}-4.1.0-tools-shared-libs.patch
+       "${FILESDIR}"/${PN}-4.4.2-c89-fix.patch
+)
+
+TSK_JAR_DIR="${S}/bindings/java/lib"
+
+src_unpack() {
+       local f
+
+       unpack ${P}.tar.gz
+
+       # Copy the jar files that don't exist in the tree yet
+       if use java; then
+               mkdir "${TSK_JAR_DIR}" || die
+               for f in ${A}; do
+                       if [[ ${f} =~ .jar$ ]]; then
+                               cp "${DISTDIR}"/"${f}" "${TSK_JAR_DIR}" || die
+                       fi
+               done
+       fi
+}
+
+src_prepare() {
+       if use java; then
+               pushd "${S}"/bindings/java &>/dev/null || die
+
+               # Prevent "make install" from installing
+               # jar files under /usr/share/java
+               # We'll use the java eclasses for this
+               sed -e '/^jar_DATA/ d;' -i Makefile.am || die
+
+               # Disable dependency retrieval using ivy
+               # We will handle it ourselves
+               sed -e '/name="compile"/ s/, retrieve-deps//' \
+                       -e '/name="dist-/ s/, init-ivy//g' \
+                       -i build.xml || die
+
+               # Even if static libs are disabled, the build system looks for
+               # the static library and fails if not present
+               # Disable that check
+               use static-libs || sed -e '/<fail unless="present" 
message="JNI/ d;' \
+                                                          -i build-unix.xml || 
die
+
+               java-pkg-opt-2_src_prepare
+
+               popd &>/dev/null || die
+       fi
+
+       # Override the doxygen output directories
+       if use doc; then
+               sed -e "/^OUTPUT_DIRECTORY/ s|=.*$|= ${T}/doc|" \
+                       -i tsk/docs/Doxyfile \
+                       -i bindings/java/doxygen/Doxyfile || die
+       fi
+
+       # It's safe to call this even after java-pkg-opt-2_src_prepare
+       # because future calls to eapply_user do nothing and return 0
+       default
+
+       eautoreconf
+}
+
+src_configure() {
+       local myeconfargs=(
+               $(use_enable java)
+               $(use_enable static-libs static)
+               $(use_enable threads multithreading)
+               $(use_with aff afflib)
+               $(use_with ewf libewf)
+               $(use_with zlib)
+       )
+
+       if use java; then
+               pushd "${S}"/bindings/java &>/dev/null || die
+               java-ant-2_src_configure
+               popd &>/dev/null || die
+       fi
+
+       econf "${myeconfargs[@]}"
+}
+
+src_compile() {
+       # Create symlinks of jars for the required dependencies
+       if use java; then
+               pushd "${S}"/bindings/java &>/dev/null || die
+
+               java-pkg_jar-from --into "${TSK_JAR_DIR}" c3p0
+               java-pkg_jar-from --into "${TSK_JAR_DIR}" jdbc-postgresql
+
+               popd &>/dev/null || die
+       fi
+
+       # Create the doc output dirs if requested
+       use doc && mkdir -p "${T}"/doc/{api-docs,jni-docs} || die
+
+       emake all $(usex doc api-docs "")
+}
+
+src_install() {
+       local f
+
+       if use java; then
+               pushd "${S}"/bindings/java &>/dev/null || die
+
+               java-pkg_dojar dist/Tsk_DataModel.jar
+
+               # Install the bundled jar files
+               pushd "${TSK_JAR_DIR}" &>/dev/null || die
+               for f in *; do
+                       # Skip the symlinks java-pkg_jar-from created
+                       [[ -f ${f} ]] || continue
+
+                       # Strip the version numbers as per eclass recommendation
+                       [[ ${f} =~ -([0-9].)+.jar$ ]] || continue
+
+                       java-pkg_newjar "${f}" "${f/${BASH_REMATCH[0]}/.jar}"
+               done
+               popd &>/dev/null || die
+
+               popd &>/dev/null || die
+       fi
+
+       default
+
+       # It unconditionally builds both api and jni docs
+       # We install conditionally based on the provided use flags
+       if use doc; then
+               dodoc -r "${T}"/doc/api-docs
+               use java && dodoc -r "${T}"/doc/jni-docs
+       fi
+
+       find "${D}" -name '*.la' -delete || die
+}

diff --git a/profiles/arch/hppa/package.use.mask 
b/profiles/arch/hppa/package.use.mask
index 56ef314ec49..89c633e16d4 100644
--- a/profiles/arch/hppa/package.use.mask
+++ b/profiles/arch/hppa/package.use.mask
@@ -4,6 +4,10 @@
 # NOTE: When masking a USE flag due to missing keywords, please file a keyword
 # request bug for the hppa arch.
 
+# Göktürk Yüksek <[email protected]> (15 Aug 2017)
+# Requires java
+app-forensics/sleuthkit java
+
 # Michał Górny <[email protected]> (08 Aug 2017)
 # Required VIDEO_CARDS=i965/radeonsi, both masked in this profile.
 media-libs/mesa vulkan

diff --git a/profiles/arch/powerpc/package.use.mask 
b/profiles/arch/powerpc/package.use.mask
index e72c68c436e..46719be03b1 100644
--- a/profiles/arch/powerpc/package.use.mask
+++ b/profiles/arch/powerpc/package.use.mask
@@ -1,6 +1,10 @@
 # Copyright 1999-2017 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
 
+# Göktürk Yüksek <[email protected]> (15 Aug 2017)
+# Requires java
+app-forensics/sleuthkit java
+
 # Michał Górny <[email protected]> (10 Aug 2017)
 # Requires USE=ipmi which is masked in this profile.
 sys-power/nut ups_drivers_nut-ipmipsu

Reply via email to