diff options
| author | Samuel John | 2012-12-14 18:59:04 +0100 |
|---|---|---|
| committer | Adam Vandenberg | 2013-01-18 18:14:34 -0800 |
| commit | 850640f274dc9adff82ef0867ba5d205ad769d60 (patch) | |
| tree | 8e00ab39f2c4c404900f69708a8f7c79edc2f539 /Library | |
| parent | 5b1f7087142ecab4750c8dc95393aa90b0bb5abe (diff) | |
| download | homebrew-850640f274dc9adff82ef0867ba5d205ad769d60.tar.bz2 | |
portmidi: Version 217, Java & Python optional.
- with-python: Proper Python bindings that ship with portmidi
- Fixes CMAKE_OSX_SYSROOT location
Note, JAVA SDK has to be installed separately on Macs,
therefore: opt-in!
Closes #16577.
Signed-off-by: Adam Vandenberg <flangy@gmail.com>
Diffstat (limited to 'Library')
| -rw-r--r-- | Library/Formula/portmidi.rb | 83 |
1 files changed, 69 insertions, 14 deletions
diff --git a/Library/Formula/portmidi.rb b/Library/Formula/portmidi.rb index 9feb0c33f..c2aae1623 100644 --- a/Library/Formula/portmidi.rb +++ b/Library/Formula/portmidi.rb @@ -2,31 +2,86 @@ require 'formula' class Portmidi < Formula homepage 'http://sourceforge.net/apps/trac/portmedia/wiki/portmidi' - url 'http://downloads.sourceforge.net/project/portmedia/portmidi/200/portmidi-src-200.zip' - sha1 'dcd979881a3b16518d33999e529004d7a647c2db' + url 'http://downloads.sourceforge.net/project/portmedia/portmidi/217/portmidi-src-217.zip' + sha1 'f45bf4e247c0d7617deacd6a65d23d9fddae6117' + + option 'with-java', 'Build java based app and bindings. You need the Java SDK for this.' + option 'with-python', 'Build the pyportmidi python module.' depends_on 'cmake' => :build + depends_on 'Cython' => :python if build.include? 'with-python' - def install - # PATCH for Snow Leopard, see https://github.com/halfbyte/portmidi - # hopefully not needed anymore in the next version of portmidi - architectures = archs_for_command('/bin/sh').join(' ') - inreplace 'CMakeLists.txt', - 'CMAKE_OSX_ARCHITECTURES i386 ppc CACHE STRING "do not build for 64-bit"', - "CMAKE_OSX_ARCHITECTURES #{architectures} CACHE STRING \"do only build for required architectures\"" + def patches + # Avoid that the Makefile.osx builds the java app and fails because: fatal error: 'jni.h' file not found + # Since 217 the Makefile.osx includes pm_common/CMakeLists.txt wich builds the Java app + DATA unless build.include? 'with-java' + end + def install inreplace 'pm_mac/Makefile.osx', 'PF=/usr/local', "PF=#{prefix}" - # Fix compilation on Mountain Lion, works on previous versions too - inreplace 'pm_mac/readbinaryplist.c', - '#include "Folders.h"', - '#include <CoreServices/CoreServices.h>' - # need to create include/lib directories since make won't create them itself include.mkpath lib.mkpath + # Fix outdated SYSROOT to avoid: No rule to make target `/Developer/SDKs/MacOSX10.5.sdk/System/Library/Frameworks/CoreAudio.framework', needed by `latency'. Stop. + inreplace 'pm_common/CMakeLists.txt', 'set(CMAKE_OSX_SYSROOT /Developer/SDKs/MacOSX10.5.sdk CACHE', "set(CMAKE_OSX_SYSROOT /#{MacOS.sdk_path} CACHE" + system 'make -f pm_mac/Makefile.osx' system 'make -f pm_mac/Makefile.osx install' + + if build.include? 'with-python' + # In order to install into the Cellar, the dir must exist and be in the + # PYTHONPATH. + temp_site_packages = lib/which_python/'site-packages' + mkdir_p temp_site_packages + ENV['PYTHONPATH'] = temp_site_packages + + args = [ + "--no-user-cfg", + "--verbose", + "install", + "--force", + "--install-scripts=#{bin}", + "--install-lib=#{temp_site_packages}", + "--install-data=#{share}", + "--install-headers=#{include}", + ] + cd 'pm_python' do + # There is no longer a CHANGES.txt or TODO.txt. + inreplace 'setup.py', "CHANGES = open('CHANGES.txt').read()", 'CHANGES = ""' + inreplace 'setup.py', "TODO = open('TODO.txt').read()", 'TODO = ""' + # Provide correct dirs (that point into the Cellar) + ENV.append 'CFLAGS', "-I#{include}" + ENV.append 'LDFLAGS', "-L#{lib}" + system "python", "-s", "setup.py", *args + end + end + end + + def which_python + "python" + `python -c 'import sys;print(sys.version[:3])'`.strip end end + +__END__ +diff --git a/pm_common/CMakeLists.txt b/pm_common/CMakeLists.txt +index e171047..b010c35 100644 +--- a/pm_common/CMakeLists.txt ++++ b/pm_common/CMakeLists.txt +@@ -112,14 +112,9 @@ target_link_libraries(portmidi-static ${PM_NEEDED_LIBS}) + # define the jni library + include_directories(${JAVA_INCLUDE_PATHS}) + +-set(JNISRC ${LIBSRC} ../pm_java/pmjni/pmjni.c) +-add_library(pmjni SHARED ${JNISRC}) +-target_link_libraries(pmjni ${JNI_EXTRA_LIBS}) +-set_target_properties(pmjni PROPERTIES EXECUTABLE_EXTENSION "jnilib") +- + # install the libraries (Linux and Mac OS X command line) + if(UNIX) +- INSTALL(TARGETS portmidi-static pmjni ++ INSTALL(TARGETS portmidi-static + LIBRARY DESTINATION /usr/local/lib + ARCHIVE DESTINATION /usr/local/lib) + # .h files installed by pm_dylib/CMakeLists.txt, so don't need them here |
