summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authordgp <dgp@users.sourceforge.net>2008-01-28 14:22:28 (GMT)
committerdgp <dgp@users.sourceforge.net>2008-01-28 14:22:28 (GMT)
commiteabe2bf04950081714881265b538ee8d12cfe6be (patch)
tree40e8d908330afcf318f577c5a745542677875543
parentf0a824abd0fb857f68260b9c657bb98dc33a5430 (diff)
downloadtk-eabe2bf04950081714881265b538ee8d12cfe6be.zip
tk-eabe2bf04950081714881265b538ee8d12cfe6be.tar.gz
tk-eabe2bf04950081714881265b538ee8d12cfe6be.tar.bz2
merge updates from HEAD
-rw-r--r--ChangeLog15
-rw-r--r--generic/ttk/ttkNotebook.c7
-rw-r--r--unix/tkUnixRFont.c208
3 files changed, 113 insertions, 117 deletions
diff --git a/ChangeLog b/ChangeLog
index eb77365..a4bbc8f 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,18 @@
+2008-01-27 Joe English <jenglish@users.sourceforge.net>
+
+ * generic/ttk/ttkNotebook.c: Make sure to schedule a
+ redisplay when adding and/or hiding tabs [Bug 1878298].
+
+2008-01-27 Joe English <jenglish@users.sourceforge.net>
+
+ * unix/tkUnixRFont.c: Merged common code from InitFont()
+ and TkpGetFontAttrsForChar(), factored into GetTkFontAttributes()
+ and GetTkFontMetrics(). Removed write-only struct UnixFtFont
+ member 'drawable'. Removed unneeded double-pointer indirections.
+ Ensure that TkFontAttributes.family member is a Tk_Uid, as
+ specified. Use FcTypeDouble for XFT_SIZE attribute.
+ Finally: fix [Bug 835848].
+
2008-01-25 Don Porter <dgp@users.sourceforge.net>
* changes: Updates for 8.5.1 release.
diff --git a/generic/ttk/ttkNotebook.c b/generic/ttk/ttkNotebook.c
index f08aedd..d11eaf7 100644
--- a/generic/ttk/ttkNotebook.c
+++ b/generic/ttk/ttkNotebook.c
@@ -1,4 +1,4 @@
-/* $Id: ttkNotebook.c,v 1.8.2.3 2007/11/25 19:19:21 dgp Exp $
+/* $Id: ttkNotebook.c,v 1.8.2.4 2008/01/28 14:22:29 dgp Exp $
* Copyright (c) 2004, Joe English
*/
@@ -239,6 +239,7 @@ static int ConfigureTab(
Tk_FreeSavedOptions(&savedOptions);
Ttk_ManagerSizeChanged(nb->notebook.mgr);
+ TtkRedisplayWidget(&nb->core);
return TCL_OK;
error:
@@ -982,6 +983,7 @@ static int NotebookForgetCommand(
}
Ttk_ForgetSlave(nb->notebook.mgr, index);
+ TtkRedisplayWidget(&nb->core);
return TCL_OK;
}
@@ -1011,6 +1013,8 @@ static int NotebookHideCommand(
SelectNearestTab(nb);
}
+ TtkRedisplayWidget(&nb->core);
+
return TCL_OK;
}
@@ -1183,7 +1187,6 @@ static int NotebookTabCommand(
SelectNearestTab(nb);
}
- TtkResizeWidget(&nb->core);
return TCL_OK;
}
diff --git a/unix/tkUnixRFont.c b/unix/tkUnixRFont.c
index 0913fa1..e262f22 100644
--- a/unix/tkUnixRFont.c
+++ b/unix/tkUnixRFont.c
@@ -8,7 +8,7 @@
* See the file "license.terms" for information on usage and redistribution of
* this file, and for a DISCLAIMER OF ALL WARRANTIES.
*
- * RCS: @(#) $Id: tkUnixRFont.c,v 1.20 2007/05/15 19:37:58 jenglish Exp $
+ * RCS: @(#) $Id: tkUnixRFont.c,v 1.20.2.1 2008/01/28 14:22:29 dgp Exp $
*/
#include "tkUnixInt.h"
@@ -33,7 +33,6 @@ typedef struct {
Display *display;
int screen;
XftDraw *ftDraw;
- Drawable drawable;
XftColor color;
} UnixFtFont;
@@ -92,6 +91,81 @@ GetFont(
/*
*---------------------------------------------------------------------------
*
+ * GetTkFontAttributes --
+ * Fill in TkFontAttributes from an XftFont.
+ */
+
+static void
+GetTkFontAttributes(
+ XftFont *ftFont,
+ TkFontAttributes *faPtr)
+{
+ char *family;
+ int weight, slant, size, pxsize;
+ double ptsize;
+
+ if (XftPatternGetString(ftFont->pattern, XFT_FAMILY, 0,
+ &family) != XftResultMatch) {
+ family = "Unknown";
+ }
+ if (XftPatternGetDouble(ftFont->pattern, XFT_SIZE, 0,
+ &ptsize) == XftResultMatch) {
+ size = (int)ptsize;
+ } else if (XftPatternGetInteger(ftFont->pattern, XFT_PIXEL_SIZE, 0,
+ &pxsize) == XftResultMatch) {
+ size = -pxsize;
+ } else {
+ size = 12;
+ }
+ if (XftPatternGetInteger(ftFont->pattern, XFT_WEIGHT, 0,
+ &weight) != XftResultMatch) {
+ weight = XFT_WEIGHT_MEDIUM;
+ }
+ if (XftPatternGetInteger(ftFont->pattern, XFT_SLANT, 0,
+ &slant) != XftResultMatch) {
+ slant = XFT_SLANT_ROMAN;
+ }
+
+#if DEBUG_FONTSEL
+ printf("family %s size %d weight %d slant %d\n",
+ family, size, weight, slant);
+#endif /* DEBUG_FONTSEL */
+
+ faPtr->family = Tk_GetUid(family);
+ faPtr->size = size;
+ faPtr->weight = (weight > XFT_WEIGHT_MEDIUM) ? TK_FW_BOLD : TK_FW_NORMAL;
+ faPtr->slant = (slant > XFT_SLANT_ROMAN) ? TK_FS_ITALIC : TK_FS_ROMAN;
+ faPtr->underline = 0;
+ faPtr->overstrike = 0;
+}
+
+/*
+ *---------------------------------------------------------------------------
+ *
+ * GetTkFontMetrics --
+ * Fill in TkFontMetrics from an XftFont.
+ */
+
+static void GetTkFontMetrics(
+ XftFont *ftFont,
+ TkFontMetrics *fmPtr)
+{
+ int spacing;
+
+ if (XftPatternGetInteger(ftFont->pattern, XFT_SPACING, 0,
+ &spacing) != XftResultMatch) {
+ spacing = XFT_PROPORTIONAL;
+ }
+
+ fmPtr->ascent = ftFont->ascent;
+ fmPtr->descent = ftFont->descent;
+ fmPtr->maxWidth = ftFont->max_advance_width;
+ fmPtr->fixed = spacing != XFT_PROPORTIONAL;
+}
+
+/*
+ *---------------------------------------------------------------------------
+ *
* InitFont --
*
* Initializes the fields of a UnixFtFont structure. If fontPtr is NULL,
@@ -109,15 +183,11 @@ InitFont(
FcPattern *pattern,
UnixFtFont *fontPtr)
{
- TkFontAttributes *faPtr;
- TkFontMetrics *fmPtr;
- char *family, **familyPtr = &family;
- int weight, slant, spacing, i;
- double size;
FcFontSet *set;
FcCharSet *charset;
FcResult result;
XftFont *ftFont;
+ int i;
if (!fontPtr) {
fontPtr = (UnixFtFont *) ckalloc(sizeof(UnixFtFont));
@@ -157,80 +227,22 @@ InitFont(
}
}
- fontPtr->font.fid = XLoadFont(Tk_Display(tkwin), "fixed");
fontPtr->display = Tk_Display(tkwin);
fontPtr->screen = Tk_ScreenNumber(tkwin);
fontPtr->ftDraw = 0;
- fontPtr->drawable = 0;
fontPtr->color.color.red = 0;
fontPtr->color.color.green = 0;
fontPtr->color.color.blue = 0;
fontPtr->color.color.alpha = 0xffff;
fontPtr->color.pixel = 0xffffffff;
- ftFont = GetFont(fontPtr, 0);
-
/*
- * Build the Tk font structure
+ * Fill in platform-specific fields of TkFont.
*/
-
- if (XftPatternGetString(ftFont->pattern, XFT_FAMILY, 0,
- familyPtr) != XftResultMatch) {
- family = "Unknown";
- }
-
- if (XftPatternGetInteger(ftFont->pattern, XFT_WEIGHT, 0,
- &weight) != XftResultMatch) {
- weight = XFT_WEIGHT_MEDIUM;
- }
- if (weight <= XFT_WEIGHT_MEDIUM) {
- weight = TK_FW_NORMAL;
- } else {
- weight = TK_FW_BOLD;
- }
-
- if (XftPatternGetInteger(ftFont->pattern, XFT_SLANT, 0,
- &slant) != XftResultMatch) {
- slant = XFT_SLANT_ROMAN;
- }
- if (slant <= XFT_SLANT_ROMAN) {
- slant = TK_FS_ROMAN;
- } else {
- slant = TK_FS_ITALIC;
- }
-
- if (XftPatternGetDouble(ftFont->pattern, XFT_SIZE, 0,
- &size) != XftResultMatch) {
- size = 12.0;
- }
-
- if (XftPatternGetInteger(ftFont->pattern, XFT_SPACING, 0,
- &spacing) != XftResultMatch) {
- spacing = XFT_PROPORTIONAL;
- }
- if (spacing == XFT_PROPORTIONAL) {
- spacing = 0;
- } else {
- spacing = 1;
- }
-#if DEBUG_FONTSEL
- printf("family %s size %g weight %d slant %d\n",
- family, size, weight, slant);
-#endif /* DEBUG_FONTSEL */
-
- faPtr = &fontPtr->font.fa;
- faPtr->family = family;
- faPtr->size = (int) size;
- faPtr->weight = weight;
- faPtr->slant = slant;
- faPtr->underline = 0;
- faPtr->overstrike = 0;
-
- fmPtr = &fontPtr->font.fm;
- fmPtr->ascent = ftFont->ascent;
- fmPtr->descent = ftFont->descent;
- fmPtr->maxWidth = ftFont->max_advance_width;
- fmPtr->fixed = spacing;
+ ftFont = GetFont(fontPtr, 0);
+ fontPtr->font.fid = XLoadFont(Tk_Display(tkwin), "fixed");
+ GetTkFontAttributes(ftFont, &fontPtr->font.fa);
+ GetTkFontMetrics(ftFont, &fontPtr->font.fm);
return fontPtr;
}
@@ -323,11 +335,11 @@ TkpGetFontFromAttributes(
XftPatternAddString(pattern, XFT_FAMILY, faPtr->family);
}
if (faPtr->size > 0) {
- XftPatternAddInteger(pattern, XFT_SIZE, faPtr->size);
+ XftPatternAddDouble(pattern, XFT_SIZE, (double)faPtr->size);
} else if (faPtr->size < 0) {
XftPatternAddInteger(pattern, XFT_PIXEL_SIZE, -faPtr->size);
} else {
- XftPatternAddInteger(pattern, XFT_SIZE, 12);
+ XftPatternAddDouble(pattern, XFT_SIZE, 12.0);
}
switch (faPtr->weight) {
case TK_FW_NORMAL:
@@ -397,7 +409,7 @@ TkpGetFontFamilies(
Tcl_Obj *resultPtr, *strPtr;
XftFontSet *list;
int i;
- char *family, **familyPtr = &family;
+ char *family;
resultPtr = Tcl_NewListObj(0, NULL);
@@ -406,7 +418,7 @@ TkpGetFontFamilies(
XFT_FAMILY, (char*)0); /* fields */
for (i = 0; i < list->nfont; i++) {
if (XftPatternGetString(list->fonts[i], XFT_FAMILY, 0,
- familyPtr) == XftResultMatch) {
+ &family) == XftResultMatch) {
strPtr = Tcl_NewStringObj(Tk_GetUid(family), -1);
Tcl_ListObjAppendElement(NULL, resultPtr, strPtr);
}
@@ -437,9 +449,7 @@ TkpGetSubFonts(
Tcl_Obj *objv[3], *listPtr, *resultPtr;
UnixFtFont *fontPtr = (UnixFtFont *) tkfont;
FcPattern *pattern;
- char *family, **familyPtr = &family;
- char *foundry, **foundryPtr = &foundry;
- char *encoding, **encodingPtr = &encoding;
+ char *family, *foundry, *encoding;
int i;
resultPtr = Tcl_NewListObj(0, NULL);
@@ -449,15 +459,15 @@ TkpGetSubFonts(
fontPtr->faces[i].source);
if (XftPatternGetString(pattern, XFT_FAMILY, 0,
- familyPtr) != XftResultMatch) {
+ &family) != XftResultMatch) {
family = "Unknown";
}
if (XftPatternGetString(pattern, XFT_FOUNDRY, 0,
- foundryPtr) != XftResultMatch) {
+ &foundry) != XftResultMatch) {
foundry = "Unknown";
}
if (XftPatternGetString(pattern, XFT_ENCODING, 0,
- encodingPtr) != XftResultMatch) {
+ &encoding) != XftResultMatch) {
encoding = "Unknown";
}
objv[0] = Tcl_NewStringObj(family, -1);
@@ -477,12 +487,6 @@ TkpGetSubFonts(
* Retrieve the font attributes of the actual font used to render a given
* character.
*
- * Results:
- * None.
- *
- * Side effects:
- * The font attributes are stored in *faPtr.
- *
*----------------------------------------------------------------------
*/
@@ -497,34 +501,10 @@ TkpGetFontAttrsForChar(
/* Structure describing the logical font */
FcChar32 ucs4 = (FcChar32) c;
/* UCS-4 character to map */
- XftFont *xftFontPtr = GetFont(fontPtr, ucs4);
+ XftFont *ftFont = GetFont(fontPtr, ucs4);
/* Actual font used to render the character */
- const char *family; /* Font family name */
- const char **familyPtr = &family;
- double size; /* Font size */
- int weight; /* Font weight */
- int slant; /* Font slant */
-
- if (XftPatternGetString(xftFontPtr->pattern, XFT_FAMILY, 0,
- familyPtr) != XftResultMatch) {
- family = "Unknown";
- }
- if (XftPatternGetDouble(xftFontPtr->pattern, XFT_SIZE, 0,
- &size) != XftResultMatch) {
- size = 12.0;
- }
- if (XftPatternGetInteger(xftFontPtr->pattern, XFT_WEIGHT, 0,
- &weight) != XftResultMatch) {
- weight = XFT_WEIGHT_MEDIUM;
- }
- if (XftPatternGetInteger(xftFontPtr->pattern, XFT_SLANT, 0,
- &slant) != XftResultMatch) {
- slant = XFT_SLANT_ROMAN;
- }
- faPtr->family = Tk_GetUid(family);
- faPtr->size = (int) size;
- faPtr->weight = (weight > XFT_WEIGHT_MEDIUM) ? TK_FW_BOLD : TK_FW_NORMAL;
- faPtr->slant = (slant > XFT_SLANT_ROMAN) ? TK_FS_ITALIC : TK_FS_ROMAN;
+
+ GetTkFontAttributes(ftFont, faPtr);
faPtr->underline = fontPtr->font.fa.underline;
faPtr->overstrike = fontPtr->font.fa.overstrike;
}
@@ -677,13 +657,11 @@ Tk_DrawChars(
fontPtr->ftDraw = XftDrawCreate(display, drawable,
DefaultVisual(display, fontPtr->screen),
DefaultColormap(display, fontPtr->screen));
- fontPtr->drawable = drawable;
} else {
Tk_ErrorHandler handler = Tk_CreateErrorHandler(display, -1, -1, -1,
NULL, (ClientData) NULL);
XftDrawChange(fontPtr->ftDraw, drawable);
- fontPtr->drawable = drawable;
Tk_DeleteErrorHandler(handler);
}
XGetGCValues(display, gc, GCForeground, &values);