git: 298fdc2dd2e3 - main - sysutils/byobu: Improve FreeBSD compatibility
Kevin Bowling
kbowling at FreeBSD.org
Thu Apr 8 19:55:55 UTC 2021
The branch main has been updated by kbowling:
URL: https://cgit.FreeBSD.org/ports/commit/?id=298fdc2dd2e3d79321fbd5ac18c725e8c07b2224
commit 298fdc2dd2e3d79321fbd5ac18c725e8c07b2224
Author: Kevin Bowling <kbowling at FreeBSD.org>
AuthorDate: 2021-04-08 19:53:53 +0000
Commit: Kevin Bowling <kbowling at FreeBSD.org>
CommitDate: 2021-04-08 19:55:20 +0000
sysutils/byobu: Improve FreeBSD compatibility
PR: 254565
Approved by: Justin Coffman <jcoffman at xsecure.io> (maintainer)
---
sysutils/byobu/Makefile | 5 +-
.../byobu/files/patch-usr_lib_byobu_cpu__count | 13 ++++
sysutils/byobu/files/patch-usr_lib_byobu_cpu__freq | 30 +++++++++
sysutils/byobu/files/patch-usr_lib_byobu_disk | 23 ++++---
.../byobu/files/patch-usr_lib_byobu_load__average | 11 ++++
sysutils/byobu/files/patch-usr_lib_byobu_memory | 77 ++++++++++++++++++++--
.../byobu/files/patch-usr_lib_byobu_time__binary | 8 +++
sysutils/byobu/files/patch-usr_lib_byobu_trash | 9 +++
sysutils/byobu/files/patch-usr_lib_byobu_uptime | 12 ++++
sysutils/byobu/pkg-message | 16 -----
10 files changed, 168 insertions(+), 36 deletions(-)
diff --git a/sysutils/byobu/Makefile b/sysutils/byobu/Makefile
index 5955362be5d8..4a17708893a2 100644
--- a/sysutils/byobu/Makefile
+++ b/sysutils/byobu/Makefile
@@ -2,6 +2,7 @@
PORTNAME= byobu
PORTVERSION= 5.133
+PORTREVISION= 1
CATEGORIES= sysutils
MASTER_SITES= http://launchpad.net/${PORTNAME}/trunk/${PORTVERSION}/+download/
DISTNAME= ${PORTNAME}_${PORTVERSION}.orig
@@ -15,7 +16,7 @@ LICENSE_FILE= ${WRKSRC}/COPYING
RUN_DEPENDS= bash:shells/bash \
gsed:textproc/gsed
-USES= autoreconf python shebangfix
+USES= autoreconf python shebangfix ncurses:port
SHEBANG_FILES= usr/lib/byobu/include/notify_osd \
usr/lib/byobu/include/config.py.in \
@@ -49,7 +50,5 @@ post-patch:
-e "s@/usr/bin/python@${PYTHON_CMD}@"
${REINPLACE_CMD} -e 's, at sysconfdir@/profile.d,$$(datadir)/@PACKAGE@,' \
${WRKSRC}/etc/profile.d/Makefile.am
- ${FIND} ${WRKSRC}/usr/lib/byobu -type f -maxdepth 1 | ${XARGS} \
- ${REINPLACE_CMD} -e 's:/proc:/compat/linux/proc:g'
.include <bsd.port.mk>
diff --git a/sysutils/byobu/files/patch-usr_lib_byobu_cpu__count b/sysutils/byobu/files/patch-usr_lib_byobu_cpu__count
new file mode 100644
index 000000000000..488987644088
--- /dev/null
+++ b/sysutils/byobu/files/patch-usr_lib_byobu_cpu__count
@@ -0,0 +1,13 @@
+--- usr/lib/byobu/cpu_count.orig 2016-04-07 22:05:52 UTC
++++ usr/lib/byobu/cpu_count
+@@ -25,7 +25,9 @@ __cpu_count_detail() {
+
+ __cpu_count() {
+ local c
+- c=$(getconf _NPROCESSORS_ONLN 2>/dev/null || grep -ci "^processor" /proc/cpuinfo)
++ c=$(getconf _NPROCESSORS_ONLN 2>/dev/null || \
++ grep -ci "^processor" /proc/cpuinfo || \
++ sysctl -n hw.ncpu)
+ [ "$c" = "1" ] || printf "%sx" "$c"
+ }
+
diff --git a/sysutils/byobu/files/patch-usr_lib_byobu_cpu__freq b/sysutils/byobu/files/patch-usr_lib_byobu_cpu__freq
new file mode 100644
index 000000000000..094594b3d855
--- /dev/null
+++ b/sysutils/byobu/files/patch-usr_lib_byobu_cpu__freq
@@ -0,0 +1,30 @@
+--- usr/lib/byobu/cpu_freq.orig 2016-04-07 22:05:52 UTC
++++ usr/lib/byobu/cpu_freq
+@@ -25,6 +25,7 @@ __cpu_freq_detail() {
+
+ __cpu_freq() {
+ local hz freq count
++
+ if [ -r "/sys/devices/system/cpu/cpu0/cpufreq/scaling_cur_freq" ]; then
+ read hz < /sys/devices/system/cpu/cpu0/cpufreq/scaling_cur_freq
+ fpdiv $hz "1000000" 1 # 1Ghz
+@@ -33,7 +34,6 @@ __cpu_freq() {
+ if egrep -q -s -i -m 1 "^cpu MHz|^clock" /proc/cpuinfo; then
+ freq=$(egrep -i -m 1 "^cpu MHz|^clock" /proc/cpuinfo | awk -F"[:.]" '{ printf "%01.1f", $2 / 1000 }')
+ else
+- # Must scale frequency by number of processors, if counting bogomips
+ count=$(getconf _NPROCESSORS_ONLN 2>/dev/null || grep -ci "^processor" /proc/cpuinfo)
+ freq=$(egrep -i -m 1 "^bogomips" /proc/cpuinfo | awk -F"[:.]" '{ print $2 }')
+ freq=$(printf "%s %s" "$freq" "$count" | awk '{printf "%01.1f\n", $1/$2/1000}')
+@@ -41,7 +41,11 @@ __cpu_freq() {
+ elif hz=$(sysctl -n hw.cpufrequency 2>/dev/null); then
+ fpdiv $hz "1000000000" 1 # 1Ghz
+ freq="$_RET"
++ elif hz=$(sysctl -n machdep.tsc_freq 2>/dev/null); then
++ fpdiv $hz "1000000000" 1
++ freq="$_RET"
+ fi
++
+ [ -n "$freq" ] || return
+ color b c W; printf "%s" "$freq"; color -; color c W; printf "%s" "$ICON_GHz"; color --
+ }
diff --git a/sysutils/byobu/files/patch-usr_lib_byobu_disk b/sysutils/byobu/files/patch-usr_lib_byobu_disk
index 5198a1d25cc6..7d8e86a147b5 100644
--- a/sysutils/byobu/files/patch-usr_lib_byobu_disk
+++ b/sysutils/byobu/files/patch-usr_lib_byobu_disk
@@ -1,25 +1,28 @@
---- usr/lib/byobu/disk.orig 2016-04-07 22:05:52 UTC
+--- usr/lib/byobu/disk.orig 2020-02-09 16:40:29 UTC
+++ usr/lib/byobu/disk
-@@ -20,7 +20,7 @@
+@@ -20,7 +20,11 @@
# along with this program. If not, see <http://www.gnu.org/licenses/>.
__disk_detail() {
- df -h -P
-+ df -h
++ if [ $(uname) = "FreeBSD" ]; then
++ df -h
++ else
++ df -h -P
++ fi
}
__disk() {
-@@ -28,11 +28,11 @@ __disk() {
- # Default to /, but let users override
- [ -z "$MONITORED_DISK" ] && MP="/" || MP="$MONITORED_DISK"
- case $MP in
-- /dev/*) MP=$(awk '$1 == m { print $2; exit(0); }' "m=$MP" /proc/mounts);;
-+ /dev/*) MP=$(awk '$1 == m { print $2; exit(0); }' "m=$MP" /compat/linux/proc/mounts);;
+@@ -32,7 +36,11 @@ __disk() {
esac
# this could be done faster with 'stat --file-system --format'
# but then we'd have to do blocks -> human units ourselves
- out=$({ df -h -P "$MP" 2>/dev/null || df -h "$MP"; } | awk 'END { printf("%s %s", $2, $5); }')
-+ out=$({ df -h "$MP" 2>/dev/null || df -h "$MP"; } | awk 'END { printf("%s %s", $2, $5); }')
++ if [ $(uname) = "FreeBSD" ]; then
++ out=$({ df -h "$MP" 2>/dev/null || df -h "$MP"; } | awk 'END { printf("%s %s", $2, $5); }')
++ else
++ out=$({ df -h -P "$MP" 2>/dev/null || df -h "$MP"; } | awk 'END { printf("%s %s", $2, $5); }')
++ fi
set -- ${out}
size=${1}; pct=${2};
unit=${size#${size%?}} # get the unit (last char)
diff --git a/sysutils/byobu/files/patch-usr_lib_byobu_load__average b/sysutils/byobu/files/patch-usr_lib_byobu_load__average
new file mode 100644
index 000000000000..c060aa5d5505
--- /dev/null
+++ b/sysutils/byobu/files/patch-usr_lib_byobu_load__average
@@ -0,0 +1,11 @@
+--- usr/lib/byobu/load_average.orig 2016-04-07 22:05:52 UTC
++++ usr/lib/byobu/load_average
+@@ -26,6 +26,8 @@ __load_average_detail() {
+ __load_average() {
+ if [ -r "/proc/loadavg" ]; then
+ read one five fifteen other < /proc/loadavg
++ elif [ $(uname) = "FreeBSD" ]; then
++ one=$(uptime | sed -En 's:.*averages\: ([[:digit:]]+\.[[:digit:]]+),.*:\1:p')
+ else
+ one=$(uptime | sed -e "s/.*://" | awk '{print $1}')
+ fi
diff --git a/sysutils/byobu/files/patch-usr_lib_byobu_memory b/sysutils/byobu/files/patch-usr_lib_byobu_memory
index b4952a8fbfae..bf08bbfac38b 100644
--- a/sysutils/byobu/files/patch-usr_lib_byobu_memory
+++ b/sysutils/byobu/files/patch-usr_lib_byobu_memory
@@ -1,11 +1,74 @@
---- usr/lib/byobu/memory.orig 2019-08-23 17:23:09 UTC
+--- usr/lib/byobu/memory.orig 2016-09-15 19:22:48 UTC
+++ usr/lib/byobu/memory
-@@ -52,7 +52,7 @@ __memory() {
- buffers_plus_cached=$(($buffers+$cached))
- # "free output" buffers and cache (output from 'free')
- fo_buffers=$(($kb_main_used - $buffers_plus_cached))
+@@ -26,16 +26,35 @@ __memory_detail() {
+ __memory() {
+ local free="" total="" buffers="" cached=""
+ local kb_main_used=0 buffers_plus_cached=0 fo_buffers=0 fo_cached=0
+- if [ -r /proc/meminfo ]; then
+- while read tok val unit; do
+- case "$tok" in
+- MemTotal:) total=${val};;
+- MemFree:) free=${val};;
+- Buffers:) buffers=${val};;
+- Cached:) cached=${val};;
+- esac
+- [ -n "${free}" -a -n "${total}" -a -n "${buffers}" -a -n "${cached}" ] && break;
+- done < /proc/meminfo
++
++ if [ $(uname) = "Linux" ]; then
++ if [ -r /proc/meminfo ]; then
++ while read tok val unit; do
++ case "$tok" in
++ MemTotal:) total=${val};;
++ MemFree:) free=${val};;
++ Buffers:) buffers=${val};;
++ Cached:) cached=${val};;
++ esac
++ [ -n "${free}" -a -n "${total}" -a -n "${buffers}" -a -n "${cached}" ] && break;
++ done < /proc/meminfo
++ fi
++ elif [ $(uname) = "FreeBSD" ]; then
++ # FreeBSD support
++ mem_phys=$(sysctl -n hw.physmem)
++ page_size=$(sysctl -n hw.pagesize)
++ mem_inactive=$(($(sysctl -n vm.stats.vm.v_inactive_count)*$page_size))
++ mem_cache=$(($(sysctl -n vm.stats.vm.v_cache_count)*$page_size))
++ mem_free=$(($(sysctl -n vm.stats.vm.v_free_count)*$page_size))
++
++ mem_avail=$(($mem_inactive+$mem_cache+$mem_free))
++ mem_used=$(($mem_phys-$mem_avail))
++
++ total=$(($mem_phys/1024))
++ free=$(($mem_avail/1024))
++
++ buffers=0
++ cached=0
+ elif eval $BYOBU_TEST vm_stat >/dev/null 2>&1; then
+ # MacOS support
+ # calculation borrowed from http://apple.stackexchange.com/a/48195/18857
+@@ -44,16 +63,18 @@ __memory() {
+ speculative_blocks=$(vm_stat | grep speculative | awk '{ print $3 }' | sed -e 's/\.//')
+ free=$((($free_blocks+speculative_blocks)*4))
+ inactive=$(($inactive_blocks*4))
+- total=$((($free+$inactive)))
++ total=$(($free+$inactive))
+ buffers=0
+ cached=0
+ fi
+- kb_main_used=$(($total-$free))
+- buffers_plus_cached=$(($buffers+$cached))
+- # "free output" buffers and cache (output from 'free')
+- fo_buffers=$(($kb_main_used - $buffers_plus_cached))
- fpdiv $((100*${fo_buffers})) "${total}" 0;
-+ fpdiv $((100*${kb_main_used})) "${total}" 0;
- usage=${_RET}
+- usage=${_RET}
++
++ kb_main_used=$(($total-$free))
++ buffers_plus_cached=$(($buffers+$cached))
++ # "free output" buffers and cache (output from 'free')
++ fo_buffers=$(($kb_main_used - $buffers_plus_cached))
++ fpdiv $((100*${fo_buffers})) "${total}" 0;
++ usage=${_RET}
++
if [ $total -ge 1048576 ]; then
fpdiv "$total" 1048567 1
+ total=${_RET}
diff --git a/sysutils/byobu/files/patch-usr_lib_byobu_time__binary b/sysutils/byobu/files/patch-usr_lib_byobu_time__binary
new file mode 100644
index 000000000000..ac5fcb4524d8
--- /dev/null
+++ b/sysutils/byobu/files/patch-usr_lib_byobu_time__binary
@@ -0,0 +1,8 @@
+--- usr/lib/byobu/time_binary.orig 2013-08-28 03:50:01 UTC
++++ usr/lib/byobu/time_binary
+@@ -172,3 +172,5 @@ fi
+ color k w
+ printf "%s" "$display_time"
+ color --
++
++# vi: syntax=sh ts=4 noexpandtab
diff --git a/sysutils/byobu/files/patch-usr_lib_byobu_trash b/sysutils/byobu/files/patch-usr_lib_byobu_trash
new file mode 100644
index 000000000000..dca0d6909af2
--- /dev/null
+++ b/sysutils/byobu/files/patch-usr_lib_byobu_trash
@@ -0,0 +1,9 @@
+--- usr/lib/byobu/trash.orig 2016-04-07 22:05:52 UTC
++++ usr/lib/byobu/trash
+@@ -34,4 +34,4 @@ __trash() {
+ printf "%s[%s]" "$ICON_TRASH" "$count"
+ }
+
+-# vi: syntax=sh ts=4 noexpandtab
++# vi: syntax=sh ts=4 noexpandtab
+\ No newline at end of file
diff --git a/sysutils/byobu/files/patch-usr_lib_byobu_uptime b/sysutils/byobu/files/patch-usr_lib_byobu_uptime
new file mode 100644
index 000000000000..25efa2075fb4
--- /dev/null
+++ b/sysutils/byobu/files/patch-usr_lib_byobu_uptime
@@ -0,0 +1,12 @@
+--- usr/lib/byobu/uptime.orig 2016-05-31 14:48:13 UTC
++++ usr/lib/byobu/uptime
+@@ -30,6 +30,9 @@ __uptime() {
+ if [ -r /proc/uptime ]; then
+ read u idle < /proc/uptime
+ u=${u%.*}
++ elif [ $(uname) = "FreeBSD" ]; then
++ u=$(sysctl -n kern.boottime | sed -En 's:.*sec = ([[:digit:]]+),.*:\1:p')
++ u=$(($(date +%s) - $u))
+ elif [ -x /usr/sbin/sysctl ]; then
+ # MacOS support
+ u=$(/usr/sbin/sysctl -n kern.boottime | cut -f4 -d' ' | cut -d',' -f1)
diff --git a/sysutils/byobu/pkg-message b/sysutils/byobu/pkg-message
deleted file mode 100644
index 9b5cb832d96f..000000000000
--- a/sysutils/byobu/pkg-message
+++ /dev/null
@@ -1,16 +0,0 @@
-[
-{ type: install
- message: <<EOM
-byobu requires linprocfs(5) mounted on /compat/linux/proc
-
-If you have not done it yet, please do the following:
-
- mkdir -p /compat/linux/proc
- mount -t linprocfs linproc /compat/linux/proc
-
-To make it permanent, you need the following line in /etc/fstab:
-
- linproc /compat/linux/proc linprocfs rw,late 0 0
-EOM
-}
-]
More information about the dev-commits-ports-all
mailing list