top: make rcfile immune from a potential locale change
The delay interval is kept in the rcfile in a floating point format and is thus susceptible to changes in the locale between invocations. So values written as #,### could not be read if a new locale uses decimal points. This commit takes control of our own decimal point and will henceforth make top immune to locale switcharoos. (now that we know a '.' + 2 spaces is squeezed to one) (everything's perfectly justified, but it's just luck) Reference(s): http://www.freelists.org/post/procps/top-has-a-localedpendent-config-file-toprc http://lists.opensuse.org/opensuse-bugs/2012-12/msg01466.html Signed-off-by: Jim Warner <james.warner@comcast.net>
This commit is contained in:
parent
688f4e7399
commit
27c2ef1e6d
16
top/top.c
16
top/top.c
@ -3061,17 +3061,20 @@ static void configs_read (void) {
|
|||||||
|
|
||||||
fp = fopen(Rc_name, "r");
|
fp = fopen(Rc_name, "r");
|
||||||
if (fp) {
|
if (fp) {
|
||||||
|
int tmp_whole, tmp_fract;
|
||||||
fbuf[0] = '\0';
|
fbuf[0] = '\0';
|
||||||
fgets(fbuf, sizeof(fbuf), fp); // ignore eyecatcher
|
fgets(fbuf, sizeof(fbuf), fp); // ignore eyecatcher
|
||||||
if (5 != fscanf(fp
|
if (6 != fscanf(fp
|
||||||
, "Id:%c, Mode_altscr=%d, Mode_irixps=%d, Delay_time=%f, Curwin=%d\n"
|
, "Id:%c, Mode_altscr=%d, Mode_irixps=%d, Delay_time=%d.%d, Curwin=%d\n"
|
||||||
, &Rc.id, &Rc.mode_altscr, &Rc.mode_irixps, &tmp_delay, &i)) {
|
, &Rc.id, &Rc.mode_altscr, &Rc.mode_irixps, &tmp_whole, &tmp_fract, &i)) {
|
||||||
p = fmtmk(N_fmt(RC_bad_files_fmt), Rc_name);
|
p = fmtmk(N_fmt(RC_bad_files_fmt), Rc_name);
|
||||||
Rc_questions = -1;
|
Rc_questions = -1;
|
||||||
goto try_inspect_entries; // maybe a faulty 'inspect' echo
|
goto try_inspect_entries; // maybe a faulty 'inspect' echo
|
||||||
}
|
}
|
||||||
// you saw that, right? (fscanf stickin' it to 'i')
|
// you saw that, right? (fscanf stickin' it to 'i')
|
||||||
Curwin = &Winstk[i];
|
Curwin = &Winstk[i];
|
||||||
|
// this may be ugly, but it keeps us locale independent...
|
||||||
|
tmp_delay = (float)tmp_whole + (float)tmp_fract / 1000;
|
||||||
|
|
||||||
for (i = 0 ; i < GROUPSMAX; i++) {
|
for (i = 0 ; i < GROUPSMAX; i++) {
|
||||||
int x;
|
int x;
|
||||||
@ -3686,9 +3689,12 @@ static void file_writerc (void) {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
fprintf(fp, "%s's " RCF_EYECATCHER, Myname);
|
fprintf(fp, "%s's " RCF_EYECATCHER, Myname);
|
||||||
fprintf(fp, "Id:%c, Mode_altscr=%d, Mode_irixps=%d, Delay_time=%.3f, Curwin=%d\n"
|
fprintf(fp, "Id:%c, Mode_altscr=%d, Mode_irixps=%d, Delay_time=%d.%d, Curwin=%d\n"
|
||||||
, RCF_VERSION_ID
|
, RCF_VERSION_ID
|
||||||
, Rc.mode_altscr, Rc.mode_irixps, Rc.delay_time, (int)(Curwin - Winstk));
|
, Rc.mode_altscr, Rc.mode_irixps
|
||||||
|
// this may be ugly, but it keeps us locale independent...
|
||||||
|
, (int)Rc.delay_time, (int)((Rc.delay_time - (int)Rc.delay_time) * 1000)
|
||||||
|
, (int)(Curwin - Winstk));
|
||||||
|
|
||||||
for (i = 0 ; i < GROUPSMAX; i++) {
|
for (i = 0 ; i < GROUPSMAX; i++) {
|
||||||
fprintf(fp, "%s\tfieldscur=%s\n"
|
fprintf(fp, "%s\tfieldscur=%s\n"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user