aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPiotr Kubaj <pkubaj@FreeBSD.org>2023-03-14 19:04:09 +0000
committerPiotr Kubaj <pkubaj@FreeBSD.org>2023-03-14 19:04:09 +0000
commitd0832991005786e302898bc727cf74cb1c7cb9e7 (patch)
treefdd00b9ddd7b8785340a75cd83819ef96d5b044f
parent8122bb9081e5dc237bdd0a7161c8ab6b3875d324 (diff)
downloadports-d0832991005786e302898bc727cf74cb1c7cb9e7.tar.gz
ports-d0832991005786e302898bc727cf74cb1c7cb9e7.zip
x11/eww: fix build on powerpc
-rw-r--r--x11/eww/files/patch-cargo-crates_kqueue-1.0.6_src_time.rs42
1 files changed, 42 insertions, 0 deletions
diff --git a/x11/eww/files/patch-cargo-crates_kqueue-1.0.6_src_time.rs b/x11/eww/files/patch-cargo-crates_kqueue-1.0.6_src_time.rs
new file mode 100644
index 000000000000..57d3f86795e6
--- /dev/null
+++ b/x11/eww/files/patch-cargo-crates_kqueue-1.0.6_src_time.rs
@@ -0,0 +1,42 @@
+--- cargo-crates/kqueue-1.0.6/src/time.rs.orig 1973-11-29 21:33:09 UTC
++++ cargo-crates/kqueue-1.0.6/src/time.rs
+@@ -1,32 +1,14 @@
+-use libc::timespec;
++use libc::{c_long, time_t, timespec};
+ use std::time::Duration;
+
+-#[cfg(not(all(
+- any(target_os = "freebsd", target_os = "macos"),
+- any(target_arch = "x86", target_arch = "powerpc")
+-)))]
+-pub(crate) fn duration_to_timespec(d: Duration) -> timespec {
+- let tv_sec = d.as_secs() as i64;
+- let tv_nsec = d.subsec_nanos() as i64;
++#[cfg(all(target_arch = "x86_64", target_pointer_width = "32"))]
++type NSec = i64;
++#[cfg(not(all(target_arch = "x86_64", target_pointer_width = "32")))]
++type NSec = c_long;
+
+- if tv_sec.is_negative() {
+- panic!("Duration seconds is negative");
+- }
+-
+- if tv_nsec.is_negative() {
+- panic!("Duration nsecs is negative");
+- }
+-
+- timespec { tv_sec, tv_nsec }
+-}
+-
+-#[cfg(all(
+- any(target_os = "freebsd", target_os = "macos"),
+- any(target_arch = "x86", target_arch = "powerpc")
+-))]
+ pub(crate) fn duration_to_timespec(d: Duration) -> timespec {
+- let tv_sec = d.as_secs() as i32;
+- let tv_nsec = d.subsec_nanos() as i32;
++ let tv_sec = d.as_secs() as time_t;
++ let tv_nsec = d.subsec_nanos() as NSec;
+
+ if tv_sec.is_negative() {
+ panic!("Duration seconds is negative");