我使用简单的脚本来制作cpu使用的动态状态栏(见下文)。在开始后,它工作,但在3-4分钟后,酒吧消失了!cpu.sh很简单(见下文)。没有ChangeSize,就没有崩溃(但是没有动态条,只有静态条)。cpu.sh提供整数,因为ChangeSize需要整数。这次撞车的原因是什么?我已经花了两天时间,不明白原因。
WindowTitle {Status}
WindowSize 120 30
##### Global Style
Font "xft:DejaVu Sans:size=8:bold"
Init
Begin
Set $probarColor = {#cccccc}
##### Widgets
ChangeBackColor 1 $probarColor
ChangeBackColor 3 $probarColor
End
PeriodicTasks
Begin
##### CPU Status
If (RemainderOfDiv (GetTime) 2) == 0 Then
Begin
Set $length = (GetOutput {echo $(bash $HOME/.fvwm/scripts/StaTux/cpu.sh)} 1 -1)
ChangeSize 3 $length 3
End
End
Widget 1
Property
Type ItemDraw
Size 120 4
Position 0 0
Flags NoFocus NoReliefString
Main
Case message of
End
Widget 2
Property
Type ItemDraw
Size 118 2
Position 1 1
Flags NoFocus NoReliefString
Main
Case message of
End
Widget 3
Property
Type ItemDraw
Size 118 2
Position 1 1
Flags NoFocus NoReliefString
Main
Case message of
Endcpu.sh
#!/bin/sh
DELAY=${1:-1}
{ cat /proc/stat; sleep "$DELAY"; cat /proc/stat; } | awk '/^cpu / {usr=$2-usr; sys=$4-sys; idle=$5-idle; iow=$6-iow} END {total=usr+sys+idle+iow; print int((total-idle)*118/total)}'发布于 2018-07-14 18:04:51
正如注释中所讨论的,当shell脚本返回的值为0时,FvwmScript似乎由于X错误BadValue而崩溃。这可能是因为它试图将窗口配置为0。
另一种解决方案是使用HDipstick小部件,它是固定长度框中的水平条。下面是一个简短但完整的例子:
WindowTitle {Status}
WindowSize 120 30
WindowPosition 900 1
Init
Begin
ChangeBackColor 3 {#000}
End
PeriodicTasks
Begin
If (RemainderOfDiv (GetTime) 2) == 0 Then
Begin
Set $length = (GetOutput {bash $HOME/.fvwm/scripts/StaTux/cpu.sh} 1 -1)
ChangeValue 3 $length
End
End
Widget 3
Property
Type HDipstick
Value 0
MinValue 0
MaxValue 200
ForeColor {#f00}
Size 110 20
Position 5 5
Main
Case message of
EndMinValue和MaxValue为您从脚本中获得的数字设置了预期的限制。我任意选择了200个。脚本的PeriodicTasks调用获取这个数字,并使用ChangeValue将Value属性设置为它。它将被缩放,除以200,乘以横条的宽度,这里在Size中给出110个像素。
在玩这个游戏时,我注意到在我的FvwmScript版本中有一个bug,它会为某些低值画一个完整的条。例如,设置700的MaxValue意味着值7到26,这就提供了一个完整的栏。

https://unix.stackexchange.com/questions/454799
复制相似问题