# HG changeset patch # User Jan Dj¸«£rv # Date 1078145493 0 # Node ID 6f75b21358273658f0f18bdd5461752ade1191b6 # Parent 0cbe097fca3752935b33b8ab9a0aa9560ca03199 * xfns.c (Fx_display_color_cells): Use number of planes to calculate how many colors can be displayed. diff -r 0cbe097fca37 -r 6f75b2135827 src/ChangeLog --- a/src/ChangeLog Mon Mar 01 07:09:38 2004 +0000 +++ b/src/ChangeLog Mon Mar 01 12:51:33 2004 +0000 @@ -1,3 +1,8 @@ +2004-03-01 Jan Dj,Ad(Brv + + * xfns.c (Fx_display_color_cells): Use number of planes to calculate + how many colors can be displayed. + 2004-03-01 Kenichi Handa * editfns.c (Ftranslate_region): Handle multibyte chars in TABLE diff -r 0cbe097fca37 -r 6f75b2135827 src/xfns.c --- a/src/xfns.c Mon Mar 01 07:09:38 2004 +0000 +++ b/src/xfns.c Mon Mar 01 12:51:33 2004 +0000 @@ -3758,8 +3758,17 @@ { struct x_display_info *dpyinfo = check_x_display_info (display); - return make_number (DisplayCells (dpyinfo->display, - XScreenNumberOfScreen (dpyinfo->screen))); + int nr_planes = DisplayPlanes (dpyinfo->display, + XScreenNumberOfScreen (dpyinfo->screen)); + + /* Truncate nr_planes to 24 to avoid integer overflow. + Some displays says 32, but only 24 bits are actually significant. + There are only very few and rare video cards that have more than + 24 significant bits. Also 24 bits is more than 16 million colors, + it "should be enough for everyone". */ + if (nr_planes > 24) nr_planes = 24; + + return make_number (1 << nr_planes); } DEFUN ("x-server-max-request-size", Fx_server_max_request_size,