diff options
author | dgp <dgp@users.sourceforge.net> | 2008-01-28 14:22:28 (GMT) |
---|---|---|
committer | dgp <dgp@users.sourceforge.net> | 2008-01-28 14:22:28 (GMT) |
commit | eabe2bf04950081714881265b538ee8d12cfe6be (patch) | |
tree | 40e8d908330afcf318f577c5a745542677875543 | |
parent | f0a824abd0fb857f68260b9c657bb98dc33a5430 (diff) | |
download | tk-eabe2bf04950081714881265b538ee8d12cfe6be.zip tk-eabe2bf04950081714881265b538ee8d12cfe6be.tar.gz tk-eabe2bf04950081714881265b538ee8d12cfe6be.tar.bz2 |
merge updates from HEAD
-rw-r--r-- | ChangeLog | 15 | ||||
-rw-r--r-- | generic/ttk/ttkNotebook.c | 7 | ||||
-rw-r--r-- | unix/tkUnixRFont.c | 208 |
3 files changed, 113 insertions, 117 deletions
@@ -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); |