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 | |
| 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')
| -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) + | 
