freebsd-ports/databases/hbase/Makefile
2021-04-06 14:50:45 -07:00

87 lines
3 KiB
Makefile

# Created by: Dmitry Sivachenko <mitya@yandex-team.ru>
PORTNAME= hbase
PORTVERSION= 1.2.1
PORTREVISION= 1
CATEGORIES= databases java
MASTER_SITES= APACHE/${PORTNAME}/${PORTVERSION} \
http://kev009.com/freebsd/:maven
DISTFILES= ${DISTNAME}-src${EXTRACT_SUFX} FreeBSD-${PORTNAME}-${PORTVERSION}-maven-repository.tar.gz:maven
DIST_SUBDIR= hadoop
MAINTAINER= ports@FreeBSD.org
COMMENT= Hadoop database, a distributed, scalable, big data store
LICENSE= APACHE20
BUILD_DEPENDS= bash:shells/bash \
cmake:devel/cmake \
${LOCALBASE}/share/java/maven3/bin/mvn:devel/maven3
RUN_DEPENDS= bash:shells/bash \
yarn:devel/hadoop2
USES= cpe
CPE_VENDOR= apache
USE_JAVA= yes
MAKE_ENV+= JAVA_HOME=${JAVA_HOME} MAVEN_OPTS="-XX:MaxPermSize=256m"
OPTIONS_DEFINE= DOCS
PORTDOCS= *
HBASE_LOGDIR= /var/log/${PORTNAME}
HBASE_RUNDIR= /var/run/${PORTNAME}
HBASE_DIST= ${WRKSRC}/hbase-assembly/target/${PORTNAME}-${PORTVERSION}
HBASE_USER= hbase
HBASE_GROUP= hbase
USERS= ${HBASE_USER}
GROUPS= ${HBASE_GROUP}
SUB_FILES= hbase-env-dist.sh pkg-message
USE_RC_SUBR= hbase_master hbase_regionserver
SUB_LIST= HBASE_USER="${HBASE_USER}" \
JAVA_HOME="${JAVA_HOME}" \
HBASE_LOG_DIR="${HBASE_LOGDIR}" \
HBASE_PID_DIR="${HBASE_RUNDIR}"
PLIST_SUB= HBASE_USER=${HBASE_USER} \
HBASE_GROUP=${HBASE_GROUP} \
HBASE_LOGDIR=${HBASE_LOGDIR} \
HBASE_RUNDIR=${HBASE_RUNDIR} \
PORTVERSION="${PORTVERSION}"
.include <bsd.port.pre.mk>
.if ${JAVA_PORT_VERSION:M*8*}
JDK18_PROFILE= ,build-with-jdk8
JDK18_SOURCE= -DcompileSource=1.8
.endif
post-patch:
${REINPLACE_CMD} -e "s#%%ETCDIR%%#${ETCDIR}#" ${WRKSRC}/conf/hbase-env.sh ${WRKSRC}/bin/hbase
${RM} ${WRKSRC}/conf/hbase-env.sh.bak ${WRKSRC}/conf/hbase-env.sh.orig
do-build:
cd ${WRKSRC} && ${SETENV} ${MAKE_ENV} ${LOCALBASE}/share/java/maven3/bin/mvn -Dmaven.repo.local=${WRKDIR}/m2 --offline clean install -Prelease,native${JDK18_PROFILE} -DskipTests ${JDK18_SOURCE}
cd ${WRKSRC} && ${SETENV} ${MAKE_ENV} ${LOCALBASE}/share/java/maven3/bin/mvn -Dmaven.repo.local=${WRKDIR}/m2 --offline install -DskipTests site assembly:single -Prelease,native${JDK18_PROFILE} ${JDK18_SOURCE}
post-build:
cd ${WRKSRC}/hbase-assembly/target && ${TAR} xf ${PORTNAME}-${PORTVERSION}-bin.tar.gz
${RM} ${HBASE_DIST}/conf/*.cmd
do-install:
${MKDIR} ${STAGEDIR}${PREFIX}/hbase/bin
cd ${HBASE_DIST}/bin && ${INSTALL_SCRIPT} *.sh hbase hirb.rb ${STAGEDIR}${PREFIX}/hbase/bin/
${MKDIR} ${STAGEDIR}${ETCDIR} ${STAGEDIR}${EXAMPLESDIR}
cd ${HBASE_DIST} && ${COPYTREE_SHARE} conf ${STAGEDIR}${EXAMPLESDIR}/
${INSTALL_DATA} ${WRKDIR}/hbase-env-dist.sh ${STAGEDIR}${ETCDIR}/
cd ${HBASE_DIST}/docs && ${COPYTREE_SHARE} "*" ${STAGEDIR}${DOCSDIR}/
cd ${HBASE_DIST} && ${COPYTREE_SHARE} hbase-webapps ${STAGEDIR}${PREFIX}/hbase/
cd ${HBASE_DIST} && ${COPYTREE_SHARE} lib ${STAGEDIR}${PREFIX}/hbase/ "! -name hadoop-*.jar"
${MKDIR} ${STAGEDIR}${HBASE_LOGDIR}
${MKDIR} ${STAGEDIR}${HBASE_RUNDIR}
${CHMOD} 644 ${STAGEDIR}${PREFIX}/hbase/lib/native/libmlockall_agent.so
${STRIP_CMD} ${STAGEDIR}${PREFIX}/hbase/lib/native/libmlockall_agent.so
.include <bsd.port.post.mk>