Bug#509828: gnome-panel: Clock applet may not update often enough with custom format
Matt Wozniski
mjw at drexel.edu
Fri Dec 26 19:55:14 UTC 2008
Package: gnome-panel
Version: 2.20.3-5
Severity: normal
When using a custom date format for the clock applet, the "Show seconds"
checkbox is disabled, but that checkbox actually has two effects - it
both controls whether seconds are displayed in some formats (12 hour, 24
hour, Internet time), and it controls whether the applet is updated once
every minute, or once every second. In the case of a custom format, the
checkbox is disabled and cannot be toggled, but the clock still updates
at a rate determined by the value that the "Show seconds" box had before
it was disabled.
Steps to reproduce:
1. Right click clock applet
2. Click "preferences"
3. Change "clock type" to "12 hour" and uncheck "show seconds"
4. Change "clock type" to "Unix time" and observe that updates happen
each second.
5. Change "clock type" to "Custom format" and type "%s" in the "Custom
format" box to display Unix time - observe that the panel does not
change each second as it ought to, but each minute instead.
6. Change "clock type" to "12 hour" and check "show seconds"
7. Change "clock type" to "Custom format" and note that the panel now
shows Unix time updating once per second.
In my opinion, the "Show seconds" button ought to not be considered for
a custom format. Alternatives include:
1. Always update after 1 second when using a custom format
This is the wrong way to do it, but it's simple and will fix the bug,
at the cost of waking up the process once per second.
2. Check the custom format for "%s", "%S", "%r", "%T", "%z", etc
Also not a great idea, since which formats contain a "seconds" value
isn't necessarily portable across platforms, and catching the format
modifiers attached to each of these would be even uglier.
3. When a custom format is used, remember the last label used for the
clock, update once per second, and see if the label ever doesn't
change for 3 updates in a row. If so, assume that it will only
change once per minute, and increase the timeout accordingly.
This way is a little tougher to implement, but seems the nicest - it
only requires a few extra bytes of memory (that can be freed when the
format is changed from custom), it does not cause the clock to update
more often than necessary once it settles down, and it still properly
handles updating the clock once per second if necessary. I'd be
happy to provide a patch if others agree that this solution is
nicest.
~Matt
More information about the pkg-gnome-maintainers
mailing list