Mercurial > emacs
diff src/termcap.c @ 53306:9e78a65be39a
(tgetst1): Scan for "%pN"; if all
N are continuous in [1,9], remove all "%pN".
author | Thien-Thi Nguyen <ttn@gnuvola.org> |
---|---|
date | Thu, 25 Dec 2003 12:12:20 +0000 |
parents | 695cf19ef79e |
children | f2856e1d7f71 |
line wrap: on
line diff
--- a/src/termcap.c Thu Dec 25 11:06:14 2003 +0000 +++ b/src/termcap.c Thu Dec 25 12:12:20 2003 +0000 @@ -284,6 +284,52 @@ } *r++ = c; } + + /* Sometimes entries have "%pN" which means use parameter N in the + next %-substitution. If all such N are continuous in the range + [1,9] we can remove each "%pN" because they are redundant, thus + reducing bandwidth requirements. True, Emacs is well beyond the + days of 150baud teletypes, but some of its users aren't much so. + + This pass could probably be integrated into the one above but + abbreviation expansion makes that effort a little more hairy than + its worth; this is cleaner. */ + { + register int last_p_param = 0; + int remove_p_params = 1; + struct { char *beg; int len; } cut[11]; + + for (cut[0].beg = p = ret; p < r - 3; p++) + { + if (!remove_p_params) + break; + if (*p == '%' && *(p + 1) == 'p') + { + if (*(p + 2) - '0' == 1 + last_p_param) + { + cut[last_p_param].len = p - cut[last_p_param].beg; + last_p_param++; + p += 3; + cut[last_p_param].beg = p; + } + else /* not continuous: bail */ + remove_p_params = 0; + if (last_p_param > 10) /* too many: bail */ + remove_p_params = 0; + } + } + if (remove_p_params && last_p_param) + { + register int i; + char *wp; + + cut[last_p_param].len = r - cut[last_p_param].beg; + for (i = 0, wp = ret; i <= last_p_param; wp += cut[i++].len) + bcopy (cut[i].beg, wp, cut[i].len); + r = wp; + } + } + *r = '\0'; /* Update *AREA. */ if (area)