diff options
-rwxr-xr-x | contrib/measure-net-speed-i3status.bash | 27 | ||||
-rwxr-xr-x | contrib/measure-net-speed.bash | 75 |
2 files changed, 102 insertions, 0 deletions
diff --git a/contrib/measure-net-speed-i3status.bash b/contrib/measure-net-speed-i3status.bash new file mode 100755 index 0000000..9f9e5ce --- /dev/null +++ b/contrib/measure-net-speed-i3status.bash @@ -0,0 +1,27 @@ +#!/bin/bash +# Public Domain +# (someone claimed the next lines would be useful for… +# people. So here goes: © 2012 Stefan Breunig +# stefan+measure-net-speed@mathphys.fsk.uni-heidelberg.de) + +# append i3status output to the measure-net-speed’s one. +# the quote and escape magic is required to get valid +# JSON output, which is expected by i3bar (if you want +# colors, that is. Otherwise plain text would be fine). +# For colors, your i3status.conf should contain: +# general { +# output_format = i3bar +# } + +# i3 config looks like this: +# bar { +# status_command measure-net-speed-i3status.bash +# } + +i3status | (read line && echo $line && while : +do + read line + dat=$(measure-net-speed.bash) + dat="[{ \"full_text\": \"${dat}\" }," + echo "${line/[/$dat}" || exit 1 +done)
\ No newline at end of file diff --git a/contrib/measure-net-speed.bash b/contrib/measure-net-speed.bash new file mode 100755 index 0000000..cef4004 --- /dev/null +++ b/contrib/measure-net-speed.bash @@ -0,0 +1,75 @@ +#!/bin/bash +# Public Domain +# (someone claimed the next lines would be useful for… +# people. So here goes: © 2012 Stefan Breunig +# stefan+measure-net-speed@mathphys.fsk.uni-heidelberg.de) + + +# path to store the old results in +path="/dev/shm/measure-net-speed" + +# grabbing data for each adapter. +# You can find the paths to your adapters using +# find /sys/devices -name statistics +# If you have more (or less) than two adapters, simply adjust the script here +# and in the next block. +eth0="/sys/devices/pci0000:00/0000:00:19.0/net/eth0/statistics" +wlan0="/sys/devices/pci0000:00/0000:00:1c.1/0000:03:00.0/net/wlan0/statistics" +read eth0_rx < "${eth0}/rx_bytes" +read eth0_tx < "${eth0}/tx_bytes" +read wlan0_rx < "${wlan0}/rx_bytes" +read wlan0_tx < "${wlan0}/tx_bytes" + +# get time and sum of rx/tx for combined display +time=$(date +%s) +rx=$(( $eth0_rx + $wlan0_rx )) +tx=$(( $eth0_tx + $wlan0_tx )) + +# write current data if file does not exist. Do not exit, this will cause +# problems if this file is sourced instead of executed as another process. +if ! [[ -f "${path}" ]]; then + echo "${time} ${rx} ${tx}" > "${path}" + chmod 0666 "${path}" +fi + +# read previous state and update data storage +read old < "${path}" +echo "${time} ${rx} ${tx}" > "${path}" + +# parse old data and calc time passed +old=(${old//;/ }) +time_diff=$(( $time - ${old[0]} )) + +# sanity check: has a positive amount of time passed +if [[ "${time_diff}" -gt 0 ]]; then + # calc bytes transferred, and their rate in byte/s + rx_diff=$(( $rx - ${old[1]} )) + tx_diff=$(( $tx - ${old[2]} )) + rx_rate=$(( $rx_diff / $time_diff )) + tx_rate=$(( $tx_diff / $time_diff )) + + # shift by 10 bytes to get KiB/s. If the value is larger than + # 1024^2 = 1048576, then display MiB/s instead (simply cut off + # the last two digits of KiB/s). Since the values only give an + # rough estimate anyway, this improper rounding is negligible. + + # incoming + rx_kib=$(( $rx_rate >> 10 )) + if [[ "$rx_rate" -gt 1048576 ]]; then + echo -n "${rx_kib:0:-3}.${rx_kib: -3:-2} M↓" + else + echo -n "${rx_kib} K↓" + fi + + echo -n " " + + # outgoing + tx_kib=$(( $tx_rate >> 10 )) + if [[ "$tx_rate" -gt 1048576 ]]; then + echo -n "${tx_kib:0:-3}.${tx_kib: -3:-2} M↑" + else + echo -n "${tx_kib} K↑" + fi +else + echo -n " ? " +fi
\ No newline at end of file |