svn commit: r348122 - in head/graphics: . mozjpeg

Steve Wills swills at FreeBSD.org
Thu Mar 13 20:00:12 UTC 2014


Author: swills
Date: Thu Mar 13 20:00:11 2014
New Revision: 348122
URL: http://svnweb.freebsd.org/changeset/ports/348122
QAT: https://qat.redports.org/buildarchive/r348122/

Log:
  MozJPEG is a fork of libjpeg-turbo with 'jpgcrush' functionality built in.
  
  The goal is to provide a production-quality JPEG encoder that improves
  compression while maintaining compatibility with the vast majority of deployed
  decoders.
  
  The 'jpgcrush' feature finds the progressive coding configuration which uses the
  fewest bits. This most frequently reduces file size by 2-10%, but those are not
  hard limits. Significantly greater reductions have been observed.
  
  Library configuration defaults are the same as for libjpeg-turbo, in order to
  make transitions as painless as possible. There are new configuration options
  for new features, but they are not enabled by default.
  
  The 'cjpeg' program defaults are not the same as for the equivalent program in
  libjpeg-turbo. The 'cjpeg' defaults for mozjpeg are set to aggressively optimize
  for smaller file sizes.
  
  WWW: https://github.com/mozilla/mozjpeg/
  
  PR:		ports/187398
  Submitted by:	Horia Racoviceanu <horia at racoviceanu.com>

Added:
  head/graphics/mozjpeg/
  head/graphics/mozjpeg/Makefile   (contents, props changed)
  head/graphics/mozjpeg/distinfo   (contents, props changed)
  head/graphics/mozjpeg/pkg-descr   (contents, props changed)
  head/graphics/mozjpeg/pkg-plist   (contents, props changed)
Modified:
  head/graphics/Makefile

Modified: head/graphics/Makefile
==============================================================================
--- head/graphics/Makefile	Thu Mar 13 19:53:38 2014	(r348121)
+++ head/graphics/Makefile	Thu Mar 13 20:00:11 2014	(r348122)
@@ -583,6 +583,7 @@
     SUBDIR += mingplot
     SUBDIR += mirage
     SUBDIR += mmrecover
+    SUBDIR += mozjpeg
     SUBDIR += mscgen
     SUBDIR += mtpaint
     SUBDIR += multican

Added: head/graphics/mozjpeg/Makefile
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ head/graphics/mozjpeg/Makefile	Thu Mar 13 20:00:11 2014	(r348122)
@@ -0,0 +1,120 @@
+# Created by: Horia Racoviceanu <horia at racoviceanu.com>
+# $FreeBSD$
+
+PORTNAME=	mozjpeg
+PORTVERSION=	1.0
+CATEGORIES=	graphics
+
+MAINTAINER=	horia at racoviceanu.com
+COMMENT=	Fork of libjpeg-turbo with 'jpgcrush' functionality
+
+LICENSE=	BSD3CLAUSE
+
+BUILD_DEPENDS=	nasm:${PORTSDIR}/devel/nasm
+
+USE_GITHUB=	yes
+GH_ACCOUNT=	mozilla
+GH_TAGNAME=	${GH_COMMIT}
+GH_COMMIT=	febf346
+
+USE_AUTOTOOLS=	aclocal:env autoconf automake libtool
+USE_LDCONFIG=	${PREFIX}/include/${PORTNAME} ${PREFIX}/lib/${PORTNAME}
+GNU_CONFIGURE=	yes
+CONFIGURE_ARGS=	--docdir=${PREFIX}/share/doc/${PORTNAME} \
+		--includedir=${PREFIX}/include/${PORTNAME} \
+		--libdir=${PREFIX}/lib/${PORTNAME}
+LIBTOOL_ARGS+=	--finish ${PREFIX}/lib/${PORTNAME}
+LDFLAGS+=	-L${PREFIX}/lib/${PORTNAME}
+
+PLIST_SUB=	PORTNAME=${PORTNAME} \
+		SOMAJORVERSION=${SOMAJORVERSION}
+
+PORTDOCS=	*
+
+DOCSRCDIR1=	${WRKSRC}/doc/html
+DOCSDIR1=	${DOCSDIR}/html
+
+DOCSRCDIR2=	${DOCSRCDIR1}/search
+DOCSDIR2=	${DOCSDIR1}/search
+
+DOC_FILES=	*.css *.html *.js *.png
+
+PORTEXAMPLES=	*
+
+OPTIONS_DEFINE=	DOCS EXAMPLES GCC SIMD TURBOJPEG
+
+OPTIONS_GROUP=	ARITHMETIC_CODING
+OPTIONS_GROUP_ARITHMETIC_CODING=	DECODING ENCODING
+
+OPTIONS_MULTI=	LIBRARIES
+OPTIONS_MULTI_LIBRARIES=	SHARED STATIC
+
+OPTIONS_SINGLE=	API_ABI_EMULATION
+OPTIONS_SINGLE_API_ABI_EMULATION=	JPEG6B JPEG7 JPEG8
+
+OPTIONS_DEFAULT=	DECODING ENCODING GCC JPEG6B SHARED SIMD STATIC TURBOJPEG
+
+OPTIONS_SUB=	yes
+
+GCC_DESC=	Use the GNU Compiler Collection (GCC) for best performance
+SIMD_DESC=	Include SIMD extensions (MMX, SSE2, NEON)
+TURBOJPEG_DESC=	Include the TurboJPEG wrapper library and associated tests
+
+ENCODING_DESC=	Enable arithmetic encoding
+DECODING_DESC=	Enable arithmetic decoding
+
+STATIC_DESC=	Build static libraries
+SHARED_DESC=	Build shared libraries
+
+JPEG6B_DESC=	API/ABI-compatible with libjpeg v6b
+JPEG7_DESC=	API/ABI-compatible with libjpeg v7 (implies arith-coding)
+JPEG8_DESC=	API/ABI-compatible with libjpeg v8 (implies arith-coding)
+
+GCC_USE=	GCC=any
+SIMD_CONFIGURE_WITH=	simd
+TURBOJPEG_CONFIGURE_WITH=	turbojpeg
+
+JPEG7_CONFIGURE_WITH=	jpeg7
+JPEG8_CONFIGURE_WITH=	jpeg8
+
+STATIC_CONFIGURE_ENABLE=	static
+SHARED_CONFIGURE_ENABLE=	shared
+
+.include <bsd.port.options.mk>
+
+.if ${PORT_OPTIONS:MJPEG6B}
+. if ! ${PORT_OPTIONS:MENCODING}
+CONFIGURE_ARGS+=	--without-arith-enc
+. endif
+. if ! ${PORT_OPTIONS:MDECODING}
+CONFIGURE_ARGS+=	--without-arith-dec
+. endif
+SOMAJORVERSION=	63
+.else
+SOMAJORVERSION=	8
+.endif
+
+post-patch:
+	@${REINPLACE_CMD} -e "s|docdir = \$$(datadir)/doc|&/mozjpeg|; \
+		s|exampledir = \$$(datadir)/doc|exampledir = ${EXAMPLESDIR}|" \
+ 			${WRKSRC}/Makefile.am
+
+run-autotools:	run-autotools-autoreconf
+
+run-autotools-autoreconf:
+	cd ${CONFIGURE_WRKSRC} && ${SETENV} ${AUTOTOOLS_ENV} ${AUTORECONF} -fiv
+
+post-install:
+	@${MKDIR} ${STAGEDIR}${DOCSDIR2}
+	${INSTALL_DATA} ${DOC_FILES:S|^|${DOCSRCDIR1}/|} ${STAGEDIR}${DOCSDIR1}
+	${INSTALL_DATA} ${DOC_FILES:S|^|${DOCSRCDIR2}/|} ${STAGEDIR}${DOCSDIR2}
+
+.if ${PORT_OPTIONS:MSHARED}
+	${STRIP_CMD} ${STAGEDIR}${PREFIX}/lib/${PORTNAME}/libjpeg.so.${SOMAJORVERSION}
+.endif
+
+.if ${PORT_OPTIONS:MSHARED} && ${PORT_OPTIONS:MTURBOJPEG}
+	${STRIP_CMD} ${STAGEDIR}${PREFIX}/lib/${PORTNAME}/libturbojpeg.so.1
+.endif
+
+.include <bsd.port.mk>

Added: head/graphics/mozjpeg/distinfo
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ head/graphics/mozjpeg/distinfo	Thu Mar 13 20:00:11 2014	(r348122)
@@ -0,0 +1,2 @@
+SHA256 (mozjpeg-1.0.tar.gz) = 6c4845d7fa0bddd77e4a209e8e81bde11af8524dcd2cb0bb10bfd9519548ec95
+SIZE (mozjpeg-1.0.tar.gz) = 1032706

Added: head/graphics/mozjpeg/pkg-descr
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ head/graphics/mozjpeg/pkg-descr	Thu Mar 13 20:00:11 2014	(r348122)
@@ -0,0 +1,19 @@
+MozJPEG is a fork of libjpeg-turbo with 'jpgcrush' functionality built in.
+
+The goal is to provide a production-quality JPEG encoder that improves
+compression while maintaining compatibility with the vast majority of deployed
+decoders.
+
+The 'jpgcrush' feature finds the progressive coding configuration which uses the
+fewest bits. This most frequently reduces file size by 2-10%, but those are not
+hard limits. Significantly greater reductions have been observed.
+
+Library configuration defaults are the same as for libjpeg-turbo, in order to
+make transitions as painless as possible. There are new configuration options
+for new features, but they are not enabled by default.
+
+The 'cjpeg' program defaults are not the same as for the equivalent program in
+libjpeg-turbo. The 'cjpeg' defaults for mozjpeg are set to aggressively optimize
+for smaller file sizes.
+
+WWW: https://github.com/mozilla/mozjpeg/

Added: head/graphics/mozjpeg/pkg-plist
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ head/graphics/mozjpeg/pkg-plist	Thu Mar 13 20:00:11 2014	(r348122)
@@ -0,0 +1,26 @@
+bin/cjpeg
+bin/djpeg
+bin/jpegtran
+bin/rdjpgcom
+%%TURBOJPEG%%bin/tjbench
+bin/wrjpgcom
+include/%%PORTNAME%%/jconfig.h
+include/%%PORTNAME%%/jerror.h
+include/%%PORTNAME%%/jmorecfg.h
+include/%%PORTNAME%%/jpeglib.h
+%%TURBOJPEG%%include/%%PORTNAME%%/turbojpeg.h
+%%STATIC%%lib/%%PORTNAME%%/libjpeg.a
+lib/%%PORTNAME%%/libjpeg.la
+%%SHARED%%lib/%%PORTNAME%%/libjpeg.so
+%%SHARED%%lib/%%PORTNAME%%/libjpeg.so.%%SOMAJORVERSION%%
+%%STATIC%%%%TURBOJPEG%%lib/%%PORTNAME%%/libturbojpeg.a
+%%TURBOJPEG%%lib/%%PORTNAME%%/libturbojpeg.la
+%%SHARED%%%%TURBOJPEG%%lib/%%PORTNAME%%/libturbojpeg.so
+%%SHARED%%%%TURBOJPEG%%lib/%%PORTNAME%%/libturbojpeg.so.1
+man/man1/cjpeg.1.gz
+man/man1/djpeg.1.gz
+man/man1/jpegtran.1.gz
+man/man1/rdjpgcom.1.gz
+man/man1/wrjpgcom.1.gz
+ at dirrm lib/%%PORTNAME%%
+ at dirrm include/%%PORTNAME%%


More information about the svn-ports-head mailing list