75 lines
2.1 KiB
Markdown
75 lines
2.1 KiB
Markdown
---
|
|
layout: page
|
|
---
|
|
# CPU widget
|
|
|
|
[![GitHub issues by-label](https://img.shields.io/github/issues-raw/streetturtle/awesome-wm-widgets/cpu)](https://github.com/streetturtle/awesome-wm-widgets/labels/cpu)
|
|
|
|
This widget shows the average CPU load among all cores of the machine:
|
|
|
|
![screenshot](../awesome-wm-widgets/assets/img/widgets/screenshots/cpu-widget/cpu.gif)
|
|
|
|
## How it works
|
|
|
|
To measure the load I took Paul Colby's bash [script](http://colby.id.au/calculating-cpu-usage-from-proc-stat/) and rewrote it in Lua, which was quite simple.
|
|
So awesome simply reads the first line of /proc/stat:
|
|
|
|
```bash
|
|
$ 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 |
|
|
| `enable_kill_button` | `false` | Show button which kills the process |
|
|
| `process_info_max_length` | `-1` | Truncate the process information. Some processes may have a very long list of parameters which won't fit in the screen, this options allows to truncate it to the given length. |
|
|
| `timeout` | 1 | How often in seconds the widget refreshes |
|
|
|
|
### Example
|
|
|
|
```lua
|
|
cpu_widget({
|
|
width = 70,
|
|
step_width = 2,
|
|
step_spacing = 0,
|
|
color = '#434c5e'
|
|
})
|
|
```
|
|
|
|
The config above results in the following widget:
|
|
|
|
![custom](../awesome-wm-widgets/assets/img/widgets/screenshots/cpu-widget/custom.png)
|
|
|
|
## Installation
|
|
|
|
Clone/download repo and use widget in **rc.lua**:
|
|
|
|
```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'
|
|
})
|
|
...
|
|
```
|