$OpenBSD: patch-tkStripchart_c,v 1.1 2001/07/30 15:33:22 espie Exp $ --- tkStripchart.c.orig Sat Mar 16 22:14:00 1996 +++ tkStripchart.c Mon Jul 30 17:25:38 2001 @@ -148,7 +148,7 @@ struct strip_struct { int scrollrequired; int guarantee_draw; int grow_up; - XFontStruct *fontPtr; /* Information about text font, or NULL. */ + Tk_Font tkfont; /* Information about text font, or NULL. */ XColor *textColorPtr; /* Color for drawing text. */ GC textGC; /* GC for drawing text. */ XColor *tickColorPtr; /* Color for drawing ticks. */ @@ -257,7 +257,7 @@ static Tk_ConfigSpec configSpecs[] = {TK_CONFIG_SYNONYM, "-fg", "stripcolor", 0, 0, 0, 0}, {TK_CONFIG_FONT, "-font", "font", "Font", - DEF_STRIPCHART_FONT, Tk_Offset(Stripchart, fontPtr), + DEF_STRIPCHART_FONT, Tk_Offset(Stripchart, tkfont), 0}, {TK_CONFIG_BOOLEAN, "-guaranteedrawing", "guaranteedrawing", "Guaranteedrawing", DEF_GUARANTEE_DRAW, @@ -570,8 +570,8 @@ DestroyStripchart(ClientData clientData) if (StripchartPtr->value != NULL) free(StripchartPtr->value); - if (StripchartPtr->fontPtr != NULL) - Tk_FreeFontStruct(StripchartPtr->fontPtr); + if (StripchartPtr->tkfont != NULL) + Tk_FreeFont(StripchartPtr->tkfont); if (StripchartPtr->textColorPtr != NULL) Tk_FreeColor(StripchartPtr->textColorPtr); @@ -631,7 +631,7 @@ ConfigureStripchart(Tcl_Interp *interp, Tk_SetBackgroundFromBorder(StripchartPtr->tkwin, StripchartPtr->border); - gcValues.font = StripchartPtr->fontPtr->fid; + gcValues.font = Tk_FontId(StripchartPtr->tkfont); gcValues.foreground = StripchartPtr->textColorPtr->pixel; newGC = Tk_GetGC(StripchartPtr->tkwin, GCForeground|GCFont, &gcValues); if (StripchartPtr->textGC != None && StripchartPtr->tkwin) { @@ -692,8 +692,11 @@ ComputeStripchartGeometry(Stripchart* St { int tt = hasatitle(StripchartPtr); int bd = StripchartPtr->borderWidth; - int lineHeight = StripchartPtr->fontPtr->ascent + - StripchartPtr->fontPtr->descent; + Tk_FontMetrics fm; + int lineHeight; + + Tk_GetFontMetrics(StripchartPtr->tkfont, &fm); + lineHeight = fm.ascent + fm.descent; Tk_GeometryRequest(StripchartPtr->tkwin, 2 * (bd + PADDING) + StripchartPtr->num_strips * @@ -726,11 +729,13 @@ DisplayStripchart(ClientData clientData) /* * Variable declarations used in the title drawing routines */ - XFontStruct *fp = StripchartPtr->fontPtr; - XCharStruct bbox; - int x, dummy; - int lineHeight = StripchartPtr->fontPtr->ascent + - StripchartPtr->fontPtr->descent; + Tk_Font tkf = StripchartPtr->tkfont; + int x; + Tk_FontMetrics fm; + int lineHeight; + + Tk_GetFontMetrics(tkf, &fm); + lineHeight = fm.ascent + fm.descent; StripchartPtr->displaybits &= ~REDRAW_PENDING; if ((StripchartPtr->tkwin == NULL) || !Tk_IsMapped(tkwin)) @@ -747,18 +752,17 @@ DisplayStripchart(ClientData clientData) * space. Otherwise left justified and clipped on the right. */ if (tt && StripchartPtr->displaybits & DISPLAY_TITLE) { - XTextExtents(fp, StripchartPtr->title, - strlen(StripchartPtr->title), - &dummy, &dummy, &dummy, &bbox); - if (bbox.lbearing + bbox.rbearing < Tk_Width(tkwin) - 2 * bd) - x = (Tk_Width(tkwin) - bbox.lbearing - bbox.rbearing)/2; + int width = Tk_TextWidth(tkf, StripchartPtr->title, + strlen(StripchartPtr->title)); + if (width < Tk_Width(tkwin) - 2 * bd) + x = (Tk_Width(tkwin) - width)/2; else x = bd + PADDING; XClearArea(Tk_Display(tkwin), Tk_WindowId(tkwin), bd, bd, Tk_Width(tkwin) - 2 * bd, lineHeight + PADDING, False); XDrawString(Tk_Display(tkwin), Tk_WindowId(tkwin), - StripchartPtr->textGC, x, fp->max_bounds.ascent + bd, + StripchartPtr->textGC, x, fm.ascent + bd, /*XXX no max_bounds */ StripchartPtr->title, strlen(StripchartPtr->title)); } /* @@ -1057,7 +1061,8 @@ static void DrawStripi(Stripchart* SPtr, int i) { Tk_Window tkwin = SPtr->tkwin; - int lineHeight = SPtr->fontPtr->ascent + SPtr->fontPtr->descent; + Tk_FontMetrics fm; + int lineHeight; int x = SPtr->borderWidth + PADDING + (i - 1) * SPtr->strip_width; int y = SPtr->borderWidth + PADDING + hasatitle(SPtr) * (lineHeight + PADDING); @@ -1066,6 +1071,9 @@ DrawStripi(Stripchart* SPtr, int i) double maxv = SPtr->max_value; double minv = SPtr->min_value; + Tk_GetFontMetrics(SPtr->tkfont, &fm); + lineHeight = fm.ascent + fm.descent; + if (i < 1 || i > SPtr->num_strips) return; @@ -1136,7 +1144,8 @@ static void ScrollStrips(Stripchart* SPtr) { Tk_Window tkwin = SPtr->tkwin; - int lineHeight = SPtr->fontPtr->ascent + SPtr->fontPtr->descent; + Tk_FontMetrics fm; + int lineHeight; int src_x = SPtr->borderWidth + PADDING + SPtr->strip_width; int src_y = SPtr->borderWidth + PADDING + hasatitle(SPtr) * (lineHeight + PADDING); @@ -1144,6 +1153,8 @@ ScrollStrips(Stripchart* SPtr) int dest_y = src_y; int w = (SPtr->num_strips - 1) * SPtr->strip_width; int h = SPtr->max_height; + + Tk_GetFontMetrics(SPtr->tkfont, &fm); XCopyArea(Tk_Display(tkwin), Tk_WindowId(tkwin), Tk_WindowId(tkwin), Tk_GetGC(tkwin, 0, NULL), src_x, src_y, w, h, dest_x, dest_y);