[125402] trunk/dports/science

michaelld at macports.org michaelld at macports.org
Tue Sep 16 15:54:36 PDT 2014


Revision: 125402
          https://trac.macports.org/changeset/125402
Author:   michaelld at macports.org
Date:     2014-09-16 15:54:36 -0700 (Tue, 16 Sep 2014)
Log Message:
-----------
gr-mac: new port.

Added Paths:
-----------
    trunk/dports/science/gr-mac/
    trunk/dports/science/gr-mac/Portfile
    trunk/dports/science/gr-mac/files/
    trunk/dports/science/gr-mac/files/patch-CMakeLists.txt.diff

Added: trunk/dports/science/gr-mac/Portfile
===================================================================
--- trunk/dports/science/gr-mac/Portfile	                        (rev 0)
+++ trunk/dports/science/gr-mac/Portfile	2014-09-16 22:54:36 UTC (rev 125402)
@@ -0,0 +1,128 @@
+# -*- coding: utf-8; mode: tcl; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- vim:fenc=utf-8:ft=tcl:et:sw=4:ts=4:sts=4
+# $Id$
+
+PortSystem          1.0
+PortGroup           cmake 1.0
+PortGroup           github 1.0
+PortGroup           active_variants 1.1
+
+github.setup        jmalsbury gr-mac 0d636dd36a8e1667198aa59631d0d87dd17c6815
+version             20140913
+checksums           rmd160 3f70e72df016eee7a8a9f2c5ee4bc77b6dabc13a \
+                    sha256 d28b32375c9d4e4169cb1c274f5921ba1280ffb546b97b7c34637330ab66598f
+
+# allow gr-mac to work with both gnuradio and gnuradio-devel ...
+
+depends_lib-append  path:lib/libgnuradio-runtime.dylib:gnuradio
+
+# ... but not with gnuradio-legacy or gnuradio-next
+
+pre-fetch {
+    if {![catch {set installed [lindex [registry_active gnuradio-legacy] 0]}]} {
+        # gnuradio-legacy is installed; this version of gr-mac does not work with gnuradio-legacy
+        ui_msg "\nError: ${name} requires the gnuradio or gnuradio-devel port, and will not work with the gnuradio-legacy port.  deactivate gnuradio-legacy, and then install or activate gnuradio or gnuradio-devel.\n"
+        return -code error "Invalid port dependency: gnuradio-legacy"
+    }
+    if {![catch {set installed [lindex [registry_active gnuradio-next] 0]}]} {
+        # gnuradio-next is installed; this version of gr-mac does not work with gnuradio-next
+        ui_msg "\nError: ${name} requires the gnuradio or gnuradio-devel port, and will not work with the gnuradio-next port.  deactivate gnuradio-next, and then install or activate gnuradio or gnuradio-devel.\n"
+            return -code error "Invalid port dependency: gnuradio-next"
+    }
+}
+
+categories          science comms
+maintainers         michaelld openmaintainer
+description         Provides augmented functionality (blocks, GRC definitions, apps, etc) for GNU Radio.
+long_description    ${description}
+license             GPL-3
+platforms           darwin
+
+depends_build-append port:pkgconfig
+depends_lib-append	port:boost
+
+# do VPATH build
+
+post-extract        { file mkdir ${workpath}/build }
+configure.dir       ${workpath}/build
+build.dir           ${workpath}/build
+
+# temporary patch to fix CMake stuff on OSX
+patchfiles-append   patch-CMakeLists.txt.diff
+
+# remove top-level library path, such that internal libraries are used
+# instead of any already-installed ones.
+
+configure.ldflags-delete -L${prefix}/lib
+
+# install CMake files into this directory;
+# for 3.7+, but will not hurt for legacy.
+
+configure.args-append \
+    -DCMAKE_MODULES_DIR=${prefix}/share/cmake
+
+# set last configure argument to the reletive path
+# to the top-level cmake source
+
+configure.post_args ../${worksrcdir}
+
+# be verbose when building, for debugging purposes
+
+build.post_args VERBOSE=1
+
+# include examples in destroot
+
+post-destroot {
+    xinstall -m 755 -d ${destroot}${prefix}/share/examples/
+    copy ${worksrcpath}/examples ${destroot}${prefix}/share/examples/mac
+}
+
+# set Python variants
+
+set pythons_suffixes {26 27}
+global chosen_python_suffix
+set chosen_python_suffix ""
+
+set pythons_ports {}
+foreach s ${pythons_suffixes} {
+    lappend pythons_ports python${s}
+}
+
+foreach s ${pythons_suffixes} {
+    set p python${s}
+    set v [join [split ${s} ""] "."]
+    set i [lsearch -exact ${pythons_ports} ${p}]
+    set c [lreplace ${pythons_ports} ${i} ${i}]
+    eval [subst {
+        variant ${p} description "Build ${name} for Python ${v}" \
+            conflicts ${c} {
+
+            set chosen_python_suffix ${s}
+
+            # require gnuradio to also have this Python variant
+            require_active_variants \
+                path:lib/libgnuradio-runtime.dylib:gnuradio ${p}
+
+            depends_lib-append \
+                port:${p}
+
+            # specify that Python version to use
+            configure.args-append \
+                -DPYTHON_EXECUTABLE=${prefix}/bin/python${v} \
+                -DPYTHON_INCLUDE_DIR=${prefix}/Library/Frameworks/Python.framework/Versions/${v}/Headers \
+                -DPYTHON_LIBRARY=${prefix}/Library/Frameworks/Python.framework/Versions/${v}/Python \
+                -DGR_PYTHON_DIR=${frameworks_dir}/Python.framework/Versions/${v}/lib/python${v}/site-packages
+        }
+    }]
+}
+
+# if no python variant is set, default to 2.7
+if {![variant_isset python26] &&
+    ![variant_isset python27]} {
+    default_variants +python27
+}
+
+# make sure -python27 was not used alone
+if {![variant_isset python26] &&
+    ![variant_isset python27]} {
+    return -code error "Exactly one Python variant must be selected."
+}


Property changes on: trunk/dports/science/gr-mac/Portfile
___________________________________________________________________
Added: svn:keywords
   + Id
Added: svn:eol-style
   + native

Added: trunk/dports/science/gr-mac/files/patch-CMakeLists.txt.diff
===================================================================
--- trunk/dports/science/gr-mac/files/patch-CMakeLists.txt.diff	                        (rev 0)
+++ trunk/dports/science/gr-mac/files/patch-CMakeLists.txt.diff	2014-09-16 22:54:36 UTC (rev 125402)
@@ -0,0 +1,51 @@
+--- CMakeLists.txt.orig	2014-09-16 17:58:15.000000000 -0400
++++ CMakeLists.txt	2014-09-16 17:59:19.000000000 -0400
+@@ -32,7 +32,8 @@
+ endif(NOT CMAKE_BUILD_TYPE)
+ set(CMAKE_BUILD_TYPE ${CMAKE_BUILD_TYPE} CACHE STRING "")
+ 
+-list(APPEND CMAKE_MODULE_PATH ${CMAKE_SOURCE_DIR}/cmake/Modules)
++#make sure our local CMake Modules path comes first
++list(INSERT CMAKE_MODULE_PATH 0 ${CMAKE_SOURCE_DIR}/cmake/Modules)
+ 
+ ########################################################################
+ # Compiler specific setup
+@@ -103,6 +104,26 @@
+ endif()
+ 
+ ########################################################################
++# On Apple only, set install name and use rpath correctly, if not already set
++########################################################################
++if(APPLE)
++    if(NOT CMAKE_INSTALL_NAME_DIR)
++        set(CMAKE_INSTALL_NAME_DIR
++            ${CMAKE_INSTALL_PREFIX}/${GR_LIBRARY_DIR} CACHE
++            PATH "Library Install Name Destination Directory" FORCE)
++    endif(NOT CMAKE_INSTALL_NAME_DIR)
++    if(NOT CMAKE_INSTALL_RPATH)
++        set(CMAKE_INSTALL_RPATH
++            ${CMAKE_INSTALL_PREFIX}/${GR_LIBRARY_DIR} CACHE
++            PATH "Library Install RPath" FORCE)
++    endif(NOT CMAKE_INSTALL_RPATH)
++    if(NOT CMAKE_BUILD_WITH_INSTALL_RPATH)
++        set(CMAKE_BUILD_WITH_INSTALL_RPATH ON CACHE
++            BOOL "Do Build Using Library Install RPath" FORCE)
++    endif(NOT CMAKE_BUILD_WITH_INSTALL_RPATH)
++endif(APPLE)
++
++########################################################################
+ # Setup the include and linker paths
+ ########################################################################
+ include_directories(
+@@ -151,6 +172,10 @@
+ ########################################################################
+ # Install cmake search helper for this library
+ ########################################################################
++if(NOT CMAKE_MODULES_DIR)
++  set(CMAKE_MODULES_DIR lib${LIB_SUFFIX}/cmake)
++endif(NOT CMAKE_MODULES_DIR)
++
+ install(FILES cmake/Modules/macConfig.cmake        
+-    DESTINATION lib/cmake/mac
++    DESTINATION ${CMAKE_MODULES_DIR}/mac
+ )
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://lists.macosforge.org/pipermail/macports-changes/attachments/20140916/b1af0a94/attachment-0001.html>


More information about the macports-changes mailing list