awesome-wm-widgets/cpu-widget
streetturtle 1b99ffd2e1
Add files via upload
2020-02-20 21:27:11 -05:00
..
README.md various cosmetic readme improvements 2019-12-15 15:55:38 -05:00
cpu-png Add files via upload 2020-02-20 21:25:29 -05:00
cpu-widget.lua use pipe(|) to split columns of the ps command + code cleanup 2020-02-16 13:54:45 -05:00
cpu.gif add screenshots of cpu widget 2019-06-02 22:06:25 -04:00
custom.png add screenshots of cpu widget 2019-06-02 22:06:25 -04:00
out.gif Add files via upload 2020-02-20 21:27:11 -05:00
out.webm Add files via upload 2020-02-20 21:20:37 -05:00

README.md

CPU widget

This widget shows the average CPU load among all cores of the machine:

screenshot

How it works

To measure the load I took Paul Colby's bash script and rewrote it in Lua, which was quite simple. So awesome simply reads the first line of /proc/stat:

$ cat /proc/stat | grep '^cpu '
cpu  197294 718 50102 2002182 3844 0 2724 0 0 0

and calculates the percentage.

Customization

It is possible to customize widget by providing a table with all or some of the following config parameters:

Name Default Description
width 50 Width of the widget
step_width 2 Width of the step
step_spacing 1 Space size between steps
color beautiful.fg_normal Color of the graph

Example

cpu_widget({
    width = 70,
    step_width = 2,
    step_spacing = 0,
    color = '#434c5e'
})

The config above results in the following widget:

custom

Installation

Clone/download repo and use widget in rc.lua:

local cpu_widget = require("awesome-wm-widgets.cpu-widget.cpu-widget")
...
s.mytasklist, -- Middle widget
	{ -- Right widgets
    	layout = wibox.layout.fixed.horizontal,
		...
		-- default
		cpu_widget(),
		-- or custom
		cpu_widget({
            width = 70,
            step_width = 2,
            step_spacing = 0,
            color = '#434c5e'
        })
		...