私はCPU使用率の動的ステータスバーを作成するために単純なスクリプトを使用しています(下記参照)。 fvwmを起動した後は動作しますが、3〜4分後にバーが消えます! cpu.shは簡単です(下記参照)。 ChangeSizeがないと競合は発生しません(ただし、動的列はなく静的列のみがあります)。 ChangeSizeには整数が必要なため、cpu.shは整数を提供します。この衝突の原因は何ですか?私はそれについて2日間を過ごし、理由を理解していません。
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
End
CPU.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)}'
答え1
コメントで申し上げたとおり、FvwmScript
Xエラーのためクラッシュが発生するようです。悪い価値シェルスクリプトから返された値が0の場合。これはおそらくウィンドウサイズを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
End
スクリプトで予想される戻り数の制限を設定しますMinValue
。MaxValue
ランダムに200個を選択しました。PeriodicTasks
スクリプト呼び出しはこの番号を取得し、それを使用して属性を設定しますChangeValue
。 200で割って水平バーの幅(ここでは110ピクセル単位)をValue
掛けてサイズを変更します。Size
これを使用している間、特定の低い値に対してバー全体を描画するFvwmScriptバージョンのバグを見つけました。たとえば、aをMaxValue
700に設定すると、7〜26の値がバー全体を提供することを意味します。