diff options
author | Mattias Andrée <maandree@operamail.com> | 2014-03-07 14:32:00 +0100 |
---|---|---|
committer | Mattias Andrée <maandree@operamail.com> | 2014-03-07 14:32:00 +0100 |
commit | 24e4319db77882ab32c140cfd8c221ecf87fd9be (patch) | |
tree | 5f68b7ac84f691a0f9acfc9141f6761ab2ec82e7 /examples/plugins/mem | |
parent | lunar (diff) | |
download | xpybar-24e4319db77882ab32c140cfd8c221ecf87fd9be.tar.gz xpybar-24e4319db77882ab32c140cfd8c221ecf87fd9be.tar.bz2 xpybar-24e4319db77882ab32c140cfd8c221ecf87fd9be.tar.xz |
mem demo
Signed-off-by: Mattias Andrée <maandree@operamail.com>
Diffstat (limited to 'examples/plugins/mem')
-rw-r--r-- | examples/plugins/mem | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/examples/plugins/mem b/examples/plugins/mem new file mode 100644 index 0000000..e594858 --- /dev/null +++ b/examples/plugins/mem @@ -0,0 +1,53 @@ +# -*- python -*- + +# A xpybar configuration example testing the features of plugins.chase + +import time +import threading + +from plugins.mem import Memory +from plugins.clock import Clock + + +OUTPUT, HEIGHT, YPOS, TOP = 0, 12, 24, True + + +clock = Clock(sync_to = Clock.SECONDS) + +start_ = start +def start(): + start_() + async(lambda : clock.continuous_sync(lambda : bar.invalidate())) + + +def redraw(): + def c(used, total): + value = used * 100 / total + colour = '39' + if value >= 20: colour = '32' + if value >= 50: colour = '33' + if value >= 90: colour = '31' + return '\033[%sm%.0f\033[0m%%' % (colour, value) + + def u(b): + unit = 0 + units = ['KB', 'MB', 'GB', 'TB', 'PB', 'EB'] + while (unit < len(units)) and (b >= 1024): + b /= 1024 + unit += 1 + return '%.0f%s' % (b, units[unit]) + + mem_ = Memory() + text = 'Mem: %s (%s cached, %s buffers, %s free) │ Swp: %s (%s cached, %s free)' + text %= (c(mem_.mem_used, mem_.mem_total), u(mem_.cached), u(mem_.buffers), u(mem_.mem_free), + c(mem_.swap_used, mem_.swap_total), u(mem_.swap_cached), u(mem_.swap_free)) + if mem_.shmem is not None: + text += ' │ Shm: %s' % c(mem_.shmem, mem_.mem_total) + if mem_.slab is not None: + text += ' │ Slab: %s' % c(mem_.slab, mem_.mem_total) + if mem_.hardware_corrupted is not None: + text += ' │ Crpt: %s' % c(mem_.hardware_corrupted, mem_.mem_total) + + bar.clear() + bar.draw_coloured_text(0, 10, 0, 2, text) + |