<pre style='margin:0'>
Chris Jones (cjones051073) pushed a commit to branch master
in repository macports-ports.
</pre>
<p><a href="https://github.com/macports/macports-ports/commit/ac2c0b1fdfcb88f1ed6f4e6ce4f5155973d5ecea">https://github.com/macports/macports-ports/commit/ac2c0b1fdfcb88f1ed6f4e6ce4f5155973d5ecea</a></p>
<pre style="white-space: pre; background: #F8F8F8"><span style='display:block; white-space:pre;color:#808000;'>commit ac2c0b1fdfcb88f1ed6f4e6ce4f5155973d5ecea
</span>Author: Chris Jones <jonesc@macports.org>
AuthorDate: Sun May 10 14:59:23 2020 +0100
<span style='display:block; white-space:pre;color:#404040;'> py-tensorflow: Try and address macOS10.13 builds
</span>---
python/py-tensorflow/Portfile | 26 ++++++++-----------
.../files/CLOCK_REALTIME-Older-OSX.patch | 30 ----------------------
2 files changed, 11 insertions(+), 45 deletions(-)
<span style='display:block; white-space:pre;color:#808080;'>diff --git a/python/py-tensorflow/Portfile b/python/py-tensorflow/Portfile
</span><span style='display:block; white-space:pre;color:#808080;'>index b212d39..8840a84 100644
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>--- a/python/py-tensorflow/Portfile
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>+++ b/python/py-tensorflow/Portfile
</span><span style='display:block; white-space:pre;background:#e0e0e0;'>@@ -40,12 +40,6 @@ if { ${os.major} < ${min_darwin} } {
</span> }
}
<span style='display:block; white-space:pre;background:#ffe0e0;'>-compiler.blacklist-append {clang < 840}
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-# require c++14
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-compiler.cxx_standard 2014
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-patch.pre_args -p1
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-
</span> # Required java version
java.version 11+
# JDK port to install if required java not found
<span style='display:block; white-space:pre;background:#e0e0e0;'>@@ -54,19 +48,21 @@ java.fallback openjdk14
</span> # declare no conflict to allow redistribution of binaries.
license_noconflict ${java.fallback}
<span style='display:block; white-space:pre;background:#e0ffe0;'>+# require c++14
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+compiler.cxx_standard 2014
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+
</span> # The oldest Xcode version to use default Xcode compiler
<span style='display:block; white-space:pre;background:#ffe0e0;'>-# Note setting here should be in sync with that in bazel
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-set tf_min_xcode 9.0
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# https://github.com/tensorflow/tensorflow/issues/39262
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+set tf_min_xcode 10.2
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+compiler.blacklist-append {clang < 1001}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+# Work out if we should be using macports clang
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+set use_mp_clang [ expr ( [ string match macports-clang-* ${configure.compiler} ] || [ vercmp ${xcodeversion} ${tf_min_xcode} ] < 0 ) ]
</span>
# https://trac.macports.org/ticket/59192
xcode_workaround.type avoid_xcode_compiler
xcode_workaround.fixed_xcode_version 11.4
<span style='display:block; white-space:pre;background:#ffe0e0;'>-if {${os.major} < 16} {
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>- # Work around for issues with clock_gettime(CLOCK_REALTIME, &ts);
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>- # https://stackoverflow.com/questions/5167269/clock-gettime-alternative-in-mac-os-x
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>- patchfiles-append CLOCK_REALTIME-Older-OSX.patch
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-}
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+#patch.pre_args -p1
</span>
variant mkl description {Enable Intel Math Kernel Library support} {
# Not obvious if this dep is needed ?
<span style='display:block; white-space:pre;background:#e0e0e0;'>@@ -130,7 +126,7 @@ if {${name} ne ${subport}} {
</span> }
# Disable Xcode detection on older OSes, as we want the
# MP provided commandline utilities to be used instead.
<span style='display:block; white-space:pre;background:#ffe0e0;'>- if { [string match macports-clang-* ${configure.compiler}] || [vercmp ${xcodeversion} ${tf_min_xcode}] < 0 } {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ if { ${use_mp_clang} } {
</span> configure.env-append BAZEL_USE_CPP_ONLY_TOOLCHAIN=1
build.env-append BAZEL_USE_CPP_ONLY_TOOLCHAIN=1
}
<span style='display:block; white-space:pre;background:#e0e0e0;'>@@ -190,7 +186,7 @@ if {${name} ne ${subport}} {
</span> foreach opt [list {*}${configure.ldflags} ] {
set tf_bazel_build_opts "${tf_bazel_build_opts} --linkopt '${opt}'"
}
<span style='display:block; white-space:pre;background:#ffe0e0;'>- if {[vercmp ${xcodeversion} ${tf_min_xcode}] < 0} {
</span><span style='display:block; white-space:pre;background:#e0ffe0;'>+ if { ${use_mp_clang} } {
</span> set tf_bazel_build_opts "${tf_bazel_build_opts} --action_env CC=${configure.cc}"
set tf_bazel_cmd "BAZEL_USE_CPP_ONLY_TOOLCHAIN=1 ${tf_bazel_cmd}"
}
<span style='display:block; white-space:pre;color:#808080;'>diff --git a/python/py-tensorflow/files/CLOCK_REALTIME-Older-OSX.patch b/python/py-tensorflow/files/CLOCK_REALTIME-Older-OSX.patch
</span>deleted file mode 100644
<span style='display:block; white-space:pre;color:#808080;'>index b897dfc..0000000
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>--- a/python/py-tensorflow/files/CLOCK_REALTIME-Older-OSX.patch
</span><span style='display:block; white-space:pre;background:#e0e0ff;'>+++ /dev/null
</span><span style='display:block; white-space:pre;background:#e0e0e0;'>@@ -1,30 +0,0 @@
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-diff --git a/tensorflow/core/platform/posix/env_time.cc b/tensorflow/core/platform/posix/env_time.cc
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-index 59a67b17aa..568f7158e0 100644
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>---- a/tensorflow/core/platform/posix/env_time.cc
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-+++ b/tensorflow/core/platform/posix/env_time.cc
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-@@ -18,6 +18,9 @@ limitations under the License.
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>- #include "tensorflow/core/platform/env_time.h"
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-+#include <mach/clock.h>
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-+#include <mach/mach.h>
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-+
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>- namespace tensorflow {
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>- namespace {
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-@@ -28,7 +31,14 @@ class PosixEnvTime : public EnvTime {
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>- uint64 NowNanos() override {
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>- struct timespec ts;
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-- clock_gettime(CLOCK_REALTIME, &ts);
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-+ //clock_gettime(CLOCK_REALTIME, &ts);
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-+ clock_serv_t cclock;
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-+ mach_timespec_t mts;
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-+ host_get_clock_service(mach_host_self(), CALENDAR_CLOCK, &cclock);
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-+ clock_get_time(cclock, &mts);
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-+ mach_port_deallocate(mach_task_self(), cclock);
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-+ ts.tv_sec = mts.tv_sec;
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>-+ ts.tv_nsec = mts.tv_nsec;
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>- return (static_cast<uint64>(ts.tv_sec) * kSecondsToNanos +
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>- static_cast<uint64>(ts.tv_nsec));
</span><span style='display:block; white-space:pre;background:#ffe0e0;'>- }
</span></pre><pre style='margin:0'>
</pre>