<pre style='margin:0'>
Ryan Schmidt (ryandesign) pushed a commit to branch master
in repository macports-ports.

</pre>
<p><a href="https://github.com/macports/macports-ports/commit/e06b3e332e37dd464f35731236e5a3e92f5b5217">https://github.com/macports/macports-ports/commit/e06b3e332e37dd464f35731236e5a3e92f5b5217</a></p>
<pre style="white-space: pre; background: #F8F8F8">The following commit(s) were added to refs/heads/master by this push:
<span style='display:block; white-space:pre;color:#404040;'>     new e06b3e332e3 py-tensorflow-metadata: Submission
</span>e06b3e332e3 is described below

<span style='display:block; white-space:pre;color:#808000;'>commit e06b3e332e37dd464f35731236e5a3e92f5b5217
</span>Author: Steven Thomas Smith <s.t.smith@ieee.org>
AuthorDate: Fri Jul 24 22:07:58 2020 -0400

<span style='display:block; white-space:pre;color:#404040;'>    py-tensorflow-metadata: Submission
</span>---
 python/py-tensorflow-metadata/Portfile | 137 +++++++++++++++++++++++++++++++++
 1 file changed, 137 insertions(+)

<span style='display:block; white-space:pre;color:#808080;'>diff --git a/python/py-tensorflow-metadata/Portfile b/python/py-tensorflow-metadata/Portfile
</span>new file mode 100644
<span style='display:block; white-space:pre;color:#808080;'>index 00000000000..5542850ff64
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>--- /dev/null
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>+++ b/python/py-tensorflow-metadata/Portfile
</span><span style='display:block; white-space:pre;background:#e0e0e0;'>@@ -0,0 +1,137 @@
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# -*- 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
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+PortSystem          1.0
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+PortGroup           github 1.0
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+PortGroup           java 1.0
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+PortGroup           python 1.0
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+github.setup        tensorflow metadata 0.28.0 v
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+revision            0
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+name                py-${github.author}-${github.project}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+platforms           darwin
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+license             Apache-2
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+maintainers         nomaintainer
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+description         Library and standards for schema and statistics.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+long_description    TensorFlow Metadata provides standard representations \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+                    for metadata that are useful when training machine \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+                    learning models with TensorFlow.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+homepage            https://github.com/tensorflow/metadata
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+checksums           rmd160  ad8357a3c917ed00ed211c62eefda02da6a51981 \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+                    sha256  06ce0decf556f98f1a32d38e2a26545ff6ccac57afeb64969f913b75a9a2eda0 \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+                    size    36000
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# Required java version
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+java.version        11+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# LTS JDK port to install if required java not found
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+java.fallback       openjdk11
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# JDK only needed at build time, but java PG sets lib dependency so
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# declare no conflict to allow redistribution of binaries.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+license_noconflict  ${java.fallback}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+python.versions     37 38 39
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+proc python_listify {tcl_list} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    set python_list {}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    foreach item [lreverse ${tcl_list}] {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+        set python_list "'${item}', ${python_list}"
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    return ${python_list}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+if {${name} ne ${subport}} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    depends_build-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+                    port:bazel-3.7 \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+                    port:py${python.version}-pip \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+                    port:py${python.version}-pkginfo \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+                    port:py${python.version}-setuptools
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    depends_run-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+                    port:py${python.version}-google-api \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+                    port:py${python.version}-protobuf3
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    # Limit the number of parallel jobs to the number of physical, not logical, cpus.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    # First current setting to ensure we would be reducing the current setting.
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    set physicalcpus [sysctl hw.physicalcpu]
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    if { ${build.jobs} > ${physicalcpus} } {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+        build.jobs ${physicalcpus}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    # Build using the wonderful bazel build system ...
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    set bazel_output_user_root ${workpath}/bazel_build
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    set bazel_cmd_opts "--max_idle_secs=15 --output_user_root=${bazel_output_user_root}"
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    set bazel_build_opts "--subcommands --verbose_failures"
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    # Limit bazel resource utilisation
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    set bazel_build_opts "${bazel_build_opts} --jobs ${build.jobs} --local_ram_resources=HOST_RAM*0.75 --local_cpu_resources=HOST_CPUS*.75"
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    # Explicitly pass SDK https://github.com/bazelbuild/rules_go/issues/1554
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    # Check versioned SDK actually exists... https://trac.macports.org/ticket/60317
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    if {[string first ${configure.sdk_version} ${configure.sdkroot}] != -1} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+        set bazel_build_opts "${bazel_build_opts} --macos_sdk_version=${configure.sdk_version}"
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    } else {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+        ui_warn "configure.sdkroot='${configure.sdkroot}' does not match configure.sdk_version='${configure.sdk_version}'"
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    # hack to try and transfer MP c, c++ and ld options to bazel...
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    foreach opt [list {*}${configure.cflags} ] {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+        set bazel_build_opts "${bazel_build_opts} --conlyopt \"${opt}\""
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    foreach opt [list {*}${configure.cxxflags} ] {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+        set bazel_build_opts "${bazel_build_opts} --cxxopt \"${opt}\""
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    foreach opt [list {*}${configure.ldflags} ] {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+        set bazel_build_opts "${bazel_build_opts} --linkopt \"${opt}\""
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    ui_debug "Bazel command options: ${bazel_cmd_opts}"
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    ui_debug "Bazel build options: ${bazel_build_opts}"
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    # see ${worksrcpath}/bazel-bin/tensorflow_metadata/move_generated_files
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    set bazel_build_workspace_path \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+                    ${workpath}/build
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    set bazel_build_proto_path \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+                    ${bazel_build_workspace_path}/tensorflow_metadata/proto/v0
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    post-extract {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+        xinstall -d \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+                    ${workpath}/bin \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+                    ${bazel_build_proto_path}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+        ln -s ${python.bin} ${workpath}/bin/python
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    # replace with patch files after this repo is a little more stable
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    post-patch {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+        reinplace -E "s|\\\[(self\\._bazel_cmd), ('run'),|\[\\1, [python_listify ${bazel_cmd_opts}] 'build',|" \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+                    ${worksrcpath}/setup.py
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+        reinplace -E "s|(self\\._additional_build_options = )\\\[\\\]|\\1\[[python_listify ${bazel_build_opts}]]|" \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+                    ${worksrcpath}/setup.py
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    # turn off -j option in build; bazel will use its own parallelism
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    use_parallel_build no
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    build.env-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+                    JAVA_HOME=${java.home} \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+                    "PATH=${workpath}/bin:$env(PATH)"
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    build.asroot    yes
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    destroot.env-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+                    JAVA_HOME=${java.home} \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+                    "PATH=${workpath}/bin:$env(PATH)"
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    destroot.asroot yes
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    test.run        yes
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    test.cmd        python${python.branch}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    test.target     ${github.author}_${github.project}/python/proto_test.py
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    test.env-append \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+                    PYTHONPATH=${worksrcpath}/build/lib
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    post-destroot {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+        set docdir ${prefix}/share/doc/${subport}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+        xinstall -d ${destroot}${docdir}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+        xinstall -m 0644 -W ${worksrcpath} LICENSE README.md \
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+            ${destroot}${docdir}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    }
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+    livecheck.type  none
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+}
</span></pre><pre style='margin:0'>

</pre>