openimageio: migrate from homebrew/science
Closes #22522. Signed-off-by: FX Coudert <fxcoudert@gmail.com>
This commit is contained in:
parent
cb29083636
commit
4c299125f0
1 changed files with 87 additions and 0 deletions
87
Formula/openimageio.rb
Normal file
87
Formula/openimageio.rb
Normal file
|
@ -0,0 +1,87 @@
|
|||
class Openimageio < Formula
|
||||
desc "Library for reading, processing and writing images"
|
||||
homepage "http://openimageio.org/"
|
||||
url "https://github.com/OpenImageIO/oiio/archive/Release-1.8.7.tar.gz"
|
||||
sha256 "ed23ecdd3e4037a411c69a6a681273d01d4a2fbcc223eac86daba77dd03fc5ed"
|
||||
head "https://github.com/OpenImageIO/oiio.git"
|
||||
|
||||
depends_on "cmake" => :build
|
||||
depends_on "pkg-config" => :build
|
||||
depends_on "boost"
|
||||
depends_on "boost-python"
|
||||
depends_on "boost-python3"
|
||||
depends_on "ffmpeg"
|
||||
depends_on "freetype"
|
||||
depends_on "giflib"
|
||||
depends_on "ilmbase"
|
||||
depends_on "jpeg"
|
||||
depends_on "libpng"
|
||||
depends_on "libraw"
|
||||
depends_on "libtiff"
|
||||
depends_on "opencolorio"
|
||||
depends_on "openexr"
|
||||
depends_on "python3"
|
||||
depends_on "webp"
|
||||
|
||||
def install
|
||||
# -DUSE_OPENSSL=OFF can be removed in 1.9, see
|
||||
# https://github.com/Homebrew/homebrew-core/pull/22522#issuecomment-364831533
|
||||
args = std_cmake_args + %w[
|
||||
-DEMBEDPLUGINS=ON
|
||||
-DUSE_FIELD3D=OFF
|
||||
-DUSE_JPEGTURBO=OFF
|
||||
-DUSE_NUKE=OFF
|
||||
-DUSE_OPENCV=OFF
|
||||
-DUSE_OPENGL=OFF
|
||||
-DUSE_OPENJPEG=OFF
|
||||
-DUSE_OPENSSL=OFF
|
||||
-DUSE_PTEX=OFF
|
||||
-DUSE_QT=OFF
|
||||
]
|
||||
|
||||
mkdir "build-with-python2" do
|
||||
system "cmake", "..", *args
|
||||
system "make", "install"
|
||||
end
|
||||
|
||||
# CMake picks up the system's python dylib, even if we have a brewed one.
|
||||
py3ver = Language::Python.major_minor_version "python3"
|
||||
py3prefix = Formula["python3"].opt_frameworks/"Python.framework/Versions/#{py3ver}"
|
||||
|
||||
ENV["PYTHONPATH"] = lib/"python#{py3ver}/site-packages"
|
||||
|
||||
args << "-DPYTHON_EXECUTABLE=#{py3prefix}/bin/python3"
|
||||
args << "-DPYTHON_LIBRARY=#{py3prefix}/lib/libpython#{py3ver}.dylib"
|
||||
args << "-DPYTHON_INCLUDE_DIR=#{py3prefix}/include/python#{py3ver}m"
|
||||
|
||||
# CMake picks up boost-python instead of boost-python3
|
||||
args << "-DBOOST_ROOT=#{Formula["boost"].opt_prefix}"
|
||||
args << "-DBoost_PYTHON_LIBRARIES=#{Formula["boost-python3"].opt_lib}/libboost_python3-mt.dylib"
|
||||
|
||||
# This is strange, but must be set to make the hack above work
|
||||
args << "-DBoost_PYTHON_LIBRARY_DEBUG=''"
|
||||
args << "-DBoost_PYTHON_LIBRARY_RELEASE=''"
|
||||
|
||||
# Need to make a second build dir, otherwise cmake picks up cached files
|
||||
# and builds against `boost-python`
|
||||
mkdir "build-with-python3" do
|
||||
system "cmake", "..", *args
|
||||
system "make", "install"
|
||||
end
|
||||
end
|
||||
|
||||
test do
|
||||
test_image = test_fixtures("test.jpg")
|
||||
assert_match "#{test_image} : 1 x 1, 3 channel, uint8 jpeg",
|
||||
shell_output("#{bin}/oiiotool --info #{test_image} 2>&1")
|
||||
|
||||
["python", "python3"].each do |python|
|
||||
output = <<~EOS
|
||||
from __future__ import print_function
|
||||
import OpenImageIO
|
||||
print(OpenImageIO.VERSION_STRING)
|
||||
EOS
|
||||
assert_match version.to_s, pipe_output(python, output, 0)
|
||||
end
|
||||
end
|
||||
end
|
Loading…
Reference in a new issue