Karel Klíč 2b04b0
diff -up emacs-23.1/src/xterm.c.fontdpi emacs-23.1/src/xterm.c
Karel Klíč b3508a
--- emacs-23.1/src/xterm.c.fontdpi	2010-01-04 09:11:45.000000000 +0100
Karel Klíč b3508a
+++ emacs-23.1/src/xterm.c	2010-01-04 11:50:19.627777180 +0100
Karel Klíč b3508a
@@ -10380,17 +10380,31 @@ x_term_init (display_name, xrm_option, r
Karel Klíč 2b04b0
 				     dpyinfo->visual, AllocNone);
Karel Klíč 2b04b0
 
Karel Klíč 2b04b0
   {
Karel Klíč 2b04b0
-    int screen_number = XScreenNumberOfScreen (dpyinfo->screen);
Karel Klíč 2b04b0
-    double pixels = DisplayHeight (dpyinfo->display, screen_number);
Karel Klíč 2b04b0
-    double mm = DisplayHeightMM (dpyinfo->display, screen_number);
Karel Klíč 2b04b0
-    /* Mac OS X 10.3's Xserver sometimes reports 0.0mm.  */
Karel Klíč 2b04b0
-    dpyinfo->resy = (mm < 1) ? 100 : pixels * 25.4 / mm;
Karel Klíč 2b04b0
-    pixels = DisplayWidth (dpyinfo->display, screen_number);
Karel Klíč 2b04b0
-    mm = DisplayWidthMM (dpyinfo->display, screen_number);
Karel Klíč 2b04b0
-    /* Mac OS X 10.3's Xserver sometimes reports 0.0mm.  */
Karel Klíč 2b04b0
-    dpyinfo->resx = (mm < 1) ? 100 : pixels * 25.4 / mm;
Karel Klíč 2b04b0
+    /* If we are using Xft, check dpi value in X resources.
Karel Klíč 2b04b0
+       It is better we use it as well, since Xft will use it, as will all
Karel Klíč 2b04b0
+       Gnome applications. If our real DPI is smaller or larger than the
Karel Klíč 2b04b0
+       one Xft uses, our font will look smaller or larger than other
Karel Klíč 2b04b0
+       for other applications, even if it is the same font name (monospace-10
Karel Klíč 2b04b0
+       for example). */
Karel Klíč 2b04b0
+    char *v = XGetDefault (dpyinfo->display, "Xft", "dpi");
Karel Klíč 2b04b0
+    double d;
Karel Klíč 2b04b0
+    if (v != NULL && sscanf (v, "%lf", &d) == 1)
Karel Klíč 2b04b0
+      dpyinfo->resy = dpyinfo->resx = d;
Karel Klíč 2b04b0
   }
Karel Klíč 2b04b0
 
Karel Klíč 2b04b0
+  if (dpyinfo->resy < 1)
Karel Klíč 2b04b0
+    {
Karel Klíč 2b04b0
+      int screen_number = XScreenNumberOfScreen (dpyinfo->screen);
Karel Klíč 2b04b0
+      double pixels = DisplayHeight (dpyinfo->display, screen_number);
Karel Klíč 2b04b0
+      double mm = DisplayHeightMM (dpyinfo->display, screen_number);
Karel Klíč 2b04b0
+      /* Mac OS X 10.3's Xserver sometimes reports 0.0mm. */
Karel Klíč 2b04b0
+      dpyinfo->resy = (mm < 1) ? 100 : pixels * 25.4 / mm;
Karel Klíč 2b04b0
+      pixels = DisplayWidth (dpyinfo->display, screen_number);
Karel Klíč 2b04b0
+      mm = DisplayWidthMM (dpyinfo->display, screen_number);
Karel Klíč 2b04b0
+      /* Mac OS X 10.3's Xserver sometimes reports 0.0mm. */
Karel Klíč 2b04b0
+      dpyinfo->resx = (mm < 1) ? 100 : pixels * 25.4 / mm;
Karel Klíč 2b04b0
+    }
Karel Klíč 2b04b0
+
Karel Klíč 2b04b0
   dpyinfo->Xatom_wm_protocols
Karel Klíč 2b04b0
     = XInternAtom (dpyinfo->display, "WM_PROTOCOLS", False);
Karel Klíč 2b04b0
   dpyinfo->Xatom_wm_take_focus
Karel Klíč b3508a