mirror of
https://github.com/Ponce/slackbuilds
synced 2024-11-06 08:26:50 +01:00
377171575b
Signed-off-by: Willy Sudiarto Raharjo <willysr@slackbuilds.org>
823 lines
28 KiB
Diff
823 lines
28 KiB
Diff
* Apply 3 changes based on revisions developed by the fedora linux team.
|
||
+ 03-fedora-patch-2.diff
|
||
--> + 04-fedora-tk8.5.6.patch.diff
|
||
+ 05-tk8.5-zoomstack.diff
|
||
* Those patches are required to solve segmentation faults that are observed
|
||
when blt is used with tcltk 8.5. We have a substantial amount of
|
||
experience using this patched version of blt in the Swarm
|
||
Simulation System (www.swarm.org) and have observed no ill-effects.
|
||
Author: Paul E. Johnson (Debian Packaging) <pauljohn32@freefaculty.org>
|
||
|
||
--- a/generic/bltTreeViewEdit.c
|
||
+++ b/generic/bltTreeViewEdit.c
|
||
@@ -1177,9 +1177,15 @@
|
||
rightPos = count;
|
||
if ((rightPos < tbPtr->selFirst) || (leftPos > tbPtr->selLast)) {
|
||
/* No part of the text fragment is selected. */
|
||
+#ifdef TK_DRAWCHARS_ANGLE
|
||
+ Tk_DrawChars(tbPtr->display, drawable, tbPtr->gc,
|
||
+ tbPtr->font, fragPtr->text, fragPtr->count,
|
||
+ x + fragPtr->x, y + fragPtr->y, 0.);
|
||
+#else
|
||
Tk_DrawChars(tbPtr->display, drawable, tbPtr->gc,
|
||
tbPtr->font, fragPtr->text, fragPtr->count,
|
||
x + fragPtr->x, y + fragPtr->y);
|
||
+#endif
|
||
continue;
|
||
}
|
||
|
||
@@ -1221,9 +1227,15 @@
|
||
width, fontMetrics.linespace,
|
||
tbPtr->selBorderWidth, tbPtr->selRelief);
|
||
}
|
||
+#ifdef TK_DRAWCHARS_ANGLE
|
||
+ Tk_DrawChars(Tk_Display(tbPtr->tkwin), drawable, tbPtr->gc,
|
||
+ tbPtr->font, fragPtr->text, fragPtr->count,
|
||
+ fragPtr->x + x, fragPtr->y + y, 0.);
|
||
+#else
|
||
Tk_DrawChars(Tk_Display(tbPtr->tkwin), drawable, tbPtr->gc,
|
||
tbPtr->font, fragPtr->text, fragPtr->count,
|
||
fragPtr->x + x, fragPtr->y + y);
|
||
+#endif
|
||
}
|
||
if ((tbPtr->flags & TEXTBOX_FOCUS) && (tbPtr->cursorOn)) {
|
||
int left, top, right, bottom;
|
||
--- a/generic/bltGrPs.c
|
||
+++ b/generic/bltGrPs.c
|
||
@@ -418,7 +418,7 @@
|
||
return Tk_ConfigureInfo(interp, graphPtr->tkwin, configSpecs,
|
||
(char *)psPtr, argv[3], flags);
|
||
}
|
||
- if (Tk_ConfigureWidget(interp, graphPtr->tkwin, configSpecs, argc - 3,
|
||
+ if (Blt_ConfigureWidget(interp, graphPtr->tkwin, configSpecs, argc - 3,
|
||
argv + 3, (char *)psPtr, flags) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
}
|
||
@@ -1124,7 +1124,7 @@
|
||
fileName = argv[3]; /* First argument is the file name. */
|
||
argv++, argc--;
|
||
}
|
||
- if (Tk_ConfigureWidget(interp, graphPtr->tkwin, configSpecs, argc - 3,
|
||
+ if (Blt_ConfigureWidget(interp, graphPtr->tkwin, configSpecs, argc - 3,
|
||
argv + 3, (char *)psPtr, TK_CONFIG_ARGV_ONLY) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
}
|
||
--- a/generic/bltGrPen.c
|
||
+++ b/generic/bltGrPen.c
|
||
@@ -215,7 +215,7 @@
|
||
Tcl_FreeProc **freeProcPtr; /* Not used. */
|
||
{
|
||
Pen *penPtr = *(Pen **)(widgRec + offset);
|
||
-
|
||
+ if ( ! penPtr ) return NULL;
|
||
return penPtr->name;
|
||
}
|
||
|
||
@@ -510,7 +510,7 @@
|
||
return Tk_ConfigureInfo(interp, graphPtr->tkwin,
|
||
penPtr->configSpecs, (char *)penPtr, options[0], flags);
|
||
}
|
||
- if (Tk_ConfigureWidget(interp, graphPtr->tkwin, penPtr->configSpecs,
|
||
+ if (Blt_ConfigureWidget(interp, graphPtr->tkwin, penPtr->configSpecs,
|
||
nOpts, options, (char *)penPtr, flags) != TCL_OK) {
|
||
break;
|
||
}
|
||
--- a/generic/bltGrHairs.c
|
||
+++ b/generic/bltGrHairs.c
|
||
@@ -390,7 +390,7 @@
|
||
return Tk_ConfigureInfo(interp, graphPtr->tkwin, configSpecs,
|
||
(char *)chPtr, argv[3], 0);
|
||
}
|
||
- if (Tk_ConfigureWidget(interp, graphPtr->tkwin, configSpecs, argc - 3,
|
||
+ if (Blt_ConfigureWidget(interp, graphPtr->tkwin, configSpecs, argc - 3,
|
||
argv + 3, (char *)chPtr, TK_CONFIG_ARGV_ONLY) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
}
|
||
--- a/generic/bltGraph.c
|
||
+++ b/generic/bltGraph.c
|
||
@@ -944,7 +944,7 @@
|
||
if (InitPens(graphPtr) != TCL_OK) {
|
||
goto error;
|
||
}
|
||
- if (Tk_ConfigureWidget(interp, tkwin, configSpecs, argc - 2, argv + 2,
|
||
+ if (Blt_ConfigureWidget(interp, tkwin, configSpecs, argc - 2, argv + 2,
|
||
(char *)graphPtr, 0) != TCL_OK) {
|
||
goto error;
|
||
}
|
||
@@ -1094,7 +1094,7 @@
|
||
return Tk_ConfigureInfo(interp, graphPtr->tkwin, configSpecs,
|
||
(char *)graphPtr, argv[2], flags);
|
||
} else {
|
||
- if (Tk_ConfigureWidget(interp, graphPtr->tkwin, configSpecs, argc - 2,
|
||
+ if (Blt_ConfigureWidget(interp, graphPtr->tkwin, configSpecs, argc - 2,
|
||
argv + 2, (char *)graphPtr, flags) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
}
|
||
--- a/generic/bltUnixDnd.c
|
||
+++ b/generic/bltUnixDnd.c
|
||
@@ -1834,7 +1834,7 @@
|
||
unsigned long gcMask;
|
||
|
||
Tk_MakeWindowExist(tokenPtr->tkwin);
|
||
- if (Tk_ConfigureWidget(interp, tokenPtr->tkwin, tokenConfigSpecs, argc,
|
||
+ if (Blt_ConfigureWidget(interp, tokenPtr->tkwin, tokenConfigSpecs, argc,
|
||
argv, (char *)tokenPtr, flags) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
}
|
||
@@ -3777,7 +3777,7 @@
|
||
return Tk_ConfigureInfo(interp, dndPtr->tkwin, configSpecs,
|
||
(char *)dndPtr, argv[3], flags);
|
||
}
|
||
- if (Tk_ConfigureWidget(interp, dndPtr->tkwin, configSpecs, argc - 3,
|
||
+ if (Blt_ConfigureWidget(interp, dndPtr->tkwin, configSpecs, argc - 3,
|
||
argv + 3, (char *)dndPtr, flags) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
}
|
||
@@ -4440,7 +4440,7 @@
|
||
dndPtr->hashPtr = hPtr;
|
||
dndPtr->dataPtr = dataPtr;
|
||
Blt_SetHashValue(hPtr, dndPtr);
|
||
- if (Tk_ConfigureWidget(interp, dndPtr->tkwin, configSpecs, argc - 3,
|
||
+ if (Blt_ConfigureWidget(interp, dndPtr->tkwin, configSpecs, argc - 3,
|
||
argv + 3, (char *)dndPtr, 0) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
}
|
||
--- a/generic/bltCanvEps.c
|
||
+++ b/generic/bltCanvEps.c
|
||
@@ -1147,7 +1147,7 @@
|
||
int width, height;
|
||
|
||
tkwin = Tk_CanvasTkwin(canvas);
|
||
- if (Tk_ConfigureWidget(interp, tkwin, configSpecs, argc,
|
||
+ if (Blt_ConfigureWidget(interp, tkwin, configSpecs, argc,
|
||
argv, (char *)epsPtr, flags) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
}
|
||
@@ -1974,10 +1974,10 @@
|
||
{
|
||
"eps", /* name */
|
||
sizeof(EpsItem), /* itemSize */
|
||
- CreateEps, /* createProc */
|
||
+ (Tk_ItemCreateProc *)CreateEps, /* createProc */
|
||
configSpecs, /* configSpecs */
|
||
- ConfigureEps, /* configureProc */
|
||
- EpsCoords, /* coordProc */
|
||
+ (Tk_ItemConfigureProc *)ConfigureEps, /* configureProc */
|
||
+ (Tk_ItemCoordProc *)EpsCoords, /* coordProc */
|
||
DeleteEps, /* deleteProc */
|
||
DisplayEps, /* displayProc */
|
||
#ifdef USE_OLD_CANVAS
|
||
@@ -2005,6 +2005,6 @@
|
||
{
|
||
Tk_CreateItemType(&epsItemType);
|
||
/* Initialize custom canvas option routines. */
|
||
- tagsOption.parseProc = Tk_CanvasTagsParseProc;
|
||
- tagsOption.printProc = Tk_CanvasTagsPrintProc;
|
||
+ tagsOption.parseProc = (Tk_OptionParseProc *)Tk_CanvasTagsParseProc;
|
||
+ tagsOption.printProc = (Tk_OptionPrintProc *)Tk_CanvasTagsPrintProc;
|
||
}
|
||
--- a/generic/bltScrollbar.c
|
||
+++ b/generic/bltScrollbar.c
|
||
@@ -913,7 +913,7 @@
|
||
GC new;
|
||
Tk_Image image;
|
||
|
||
- if (Tk_ConfigureWidget(interp, scrollPtr->tkwin, configSpecs,
|
||
+ if (Blt_ConfigureWidget(interp, scrollPtr->tkwin, configSpecs,
|
||
argc, argv, (char *)scrollPtr, flags) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
}
|
||
--- a/generic/bltTreeViewStyle.c
|
||
+++ b/generic/bltTreeViewStyle.c
|
||
@@ -560,6 +560,11 @@
|
||
}
|
||
|
||
/*ARGSUSED*/
|
||
+
|
||
+int
|
||
+Blt_TreeViewTextbox(TreeView *tvPtr,
|
||
+ TreeViewEntry *entryPtr,
|
||
+ TreeViewColumn *columnPtr);
|
||
static int
|
||
FreeIcon(clientData, display, widgRec, offset, oldPtr)
|
||
ClientData clientData;
|
||
--- a/generic/bltDragdrop.c
|
||
+++ b/generic/bltDragdrop.c
|
||
@@ -1065,7 +1065,7 @@
|
||
Token *tokenPtr;
|
||
|
||
tokenPtr = &(srcPtr->token);
|
||
- if (Tk_ConfigureWidget(interp, srcPtr->tkwin, tokenConfigSpecs, argc, argv,
|
||
+ if (Blt_ConfigureWidget(interp, srcPtr->tkwin, tokenConfigSpecs, argc, argv,
|
||
(char *)tokenPtr, TK_CONFIG_ARGV_ONLY) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
}
|
||
@@ -1293,7 +1293,7 @@
|
||
/*
|
||
* Handle the bulk of the options...
|
||
*/
|
||
- if (Tk_ConfigureWidget(interp, srcPtr->tkwin, configSpecs, argc, argv,
|
||
+ if (Blt_ConfigureWidget(interp, srcPtr->tkwin, configSpecs, argc, argv,
|
||
(char *)srcPtr, flags) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
}
|
||
--- a/generic/bltAlloc.c
|
||
+++ b/generic/bltAlloc.c
|
||
@@ -40,14 +40,23 @@
|
||
* Tcl_Alloc/Tcl_Free routines because they don't automatically cause
|
||
* a panic when not enough memory is available. There are cases (such
|
||
* as allocating a very large vector) where it's recoverable.
|
||
+ *
|
||
+ * Using private is dangerous.
|
||
+ * Tcl changes mem functions for debug which will conflict then with BLT
|
||
+ * stick to public API
|
||
*/
|
||
-EXTERN Blt_MallocProc TclpAlloc;
|
||
-EXTERN Blt_FreeProc TclpFree;
|
||
-EXTERN Blt_ReallocProc TclpRealloc;
|
||
+//EXTERN Blt_MallocProc TclpAlloc;
|
||
+//EXTERN Blt_FreeProc TclpFree;
|
||
+//EXTERN Blt_ReallocProc TclpRealloc;
|
||
+
|
||
+//Blt_MallocProc *Blt_MallocProcPtr = TclpAlloc;
|
||
+//Blt_FreeProc *Blt_FreeProcPtr = TclpFree;
|
||
+//Blt_ReallocProc *Blt_ReallocProcPtr = TclpRealloc;
|
||
+
|
||
+Blt_MallocProc *Blt_MallocProcPtr = (Blt_MallocProc *)Tcl_Alloc;
|
||
+Blt_FreeProc *Blt_FreeProcPtr = (Blt_FreeProc *)Tcl_Free;
|
||
+Blt_ReallocProc *Blt_ReallocProcPtr = (Blt_ReallocProc *)Tcl_Realloc;
|
||
|
||
-Blt_MallocProc *Blt_MallocProcPtr = TclpAlloc;
|
||
-Blt_FreeProc *Blt_FreeProcPtr = TclpFree;
|
||
-Blt_ReallocProc *Blt_ReallocProcPtr = TclpRealloc;
|
||
#else
|
||
|
||
Blt_MallocProc *Blt_MallocProcPtr = malloc;
|
||
--- a/generic/bltGrLegd.c
|
||
+++ b/generic/bltGrLegd.c
|
||
@@ -1406,7 +1406,7 @@
|
||
return Tk_ConfigureInfo(interp, graphPtr->tkwin, configSpecs,
|
||
(char *)legendPtr, argv[3], flags);
|
||
}
|
||
- if (Tk_ConfigureWidget(interp, graphPtr->tkwin, configSpecs, argc - 3,
|
||
+ if (Blt_ConfigureWidget(interp, graphPtr->tkwin, configSpecs, argc - 3,
|
||
argv + 3, (char *)legendPtr, flags) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
}
|
||
--- a/generic/bltHierbox.c
|
||
+++ b/generic/bltHierbox.c
|
||
@@ -3321,7 +3321,7 @@
|
||
XColor *colorPtr;
|
||
|
||
hierBox = hboxPtr;
|
||
- if (Tk_ConfigureWidget(hboxPtr->interp, hboxPtr->tkwin, entryConfigSpecs,
|
||
+ if (Blt_ConfigureWidget(hboxPtr->interp, hboxPtr->tkwin, entryConfigSpecs,
|
||
argc, argv, (char *)entryPtr, flags) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
}
|
||
@@ -3935,7 +3935,7 @@
|
||
Tk_Uid nameId;
|
||
Pixmap bitmap;
|
||
hierBox = hboxPtr;
|
||
- if (Tk_ConfigureWidget(interp, hboxPtr->tkwin, configSpecs, argc, argv,
|
||
+ if (Blt_ConfigureWidget(interp, hboxPtr->tkwin, configSpecs, argc, argv,
|
||
(char *)hboxPtr, flags) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
}
|
||
@@ -4443,7 +4443,7 @@
|
||
Drawable drawable; /* Pixmap or window to draw into. */
|
||
{
|
||
Entry *entryPtr; /* Entry to be drawn. */
|
||
- int x1, y1, x2, y2;
|
||
+ int x1, y1i, x2, y2;
|
||
int height;
|
||
int x, y;
|
||
|
||
@@ -4463,22 +4463,22 @@
|
||
y += (height - hboxPtr->button.height) / 2;
|
||
x1 = x2 = x + LEVELWIDTH(treePtr->level) +
|
||
LEVELWIDTH(treePtr->level + 1) / 2;
|
||
- y1 = y + hboxPtr->button.height / 2;
|
||
- y2 = y1 + entryPtr->lineHeight;
|
||
+ y1i = y + hboxPtr->button.height / 2;
|
||
+ y2 = y1i + entryPtr->lineHeight;
|
||
if ((treePtr == hboxPtr->rootPtr) && (hboxPtr->hideRoot)) {
|
||
- y1 += entryPtr->height;
|
||
+ y1i += entryPtr->height;
|
||
}
|
||
/*
|
||
* Clip the line's Y-coordinates at the window border.
|
||
*/
|
||
- if (y1 < 0) {
|
||
- y1 = 0;
|
||
+ if (y1i < 0) {
|
||
+ y1i = 0;
|
||
}
|
||
if (y2 > Tk_Height(hboxPtr->tkwin)) {
|
||
y2 = Tk_Height(hboxPtr->tkwin);
|
||
}
|
||
- if ((y1 < Tk_Height(hboxPtr->tkwin)) && (y2 > 0)) {
|
||
- XDrawLine(hboxPtr->display, drawable, hboxPtr->lineGC, x1, y1,
|
||
+ if ((y1i < Tk_Height(hboxPtr->tkwin)) && (y2 > 0)) {
|
||
+ XDrawLine(hboxPtr->display, drawable, hboxPtr->lineGC, x1, y1i,
|
||
x2, y2);
|
||
}
|
||
}
|
||
@@ -4788,17 +4788,17 @@
|
||
x, y);
|
||
}
|
||
if ((isFocused) && (hboxPtr->focusEdit) && (editPtr->cursorOn)) {
|
||
- int x1, y1, x2, y2;
|
||
+ int x1, y1i, x2, y2;
|
||
|
||
GetCursorLocation(hboxPtr, treePtr);
|
||
x1 = x + editPtr->x;
|
||
x2 = x1 + 3;
|
||
- y1 = y + editPtr->y - 1;
|
||
- y2 = y1 + editPtr->height - 1;
|
||
+ y1i = y + editPtr->y - 1;
|
||
+ y2 = y1i + editPtr->height - 1;
|
||
XDrawLine(hboxPtr->display, drawable, entryPtr->labelGC,
|
||
- x1, y1, x1, y2);
|
||
+ x1, y1i, x1, y2);
|
||
XDrawLine(hboxPtr->display, drawable, entryPtr->labelGC,
|
||
- x1 - 2, y1, x2, y1);
|
||
+ x1 - 2, y1i, x2, y1i);
|
||
XDrawLine(hboxPtr->display, drawable, entryPtr->labelGC,
|
||
x1 - 2, y2, x2, y2);
|
||
}
|
||
@@ -4859,7 +4859,7 @@
|
||
int width, height;
|
||
int entryHeight;
|
||
int buttonY;
|
||
- int x1, y1, x2, y2;
|
||
+ int x1, y1i, x2, y2;
|
||
Entry *entryPtr;
|
||
|
||
entryPtr = treePtr->entryPtr;
|
||
@@ -4875,7 +4875,7 @@
|
||
buttonY = y + entryPtr->buttonY;
|
||
|
||
x1 = x + (width / 2);
|
||
- y1 = y2 = buttonY + (buttonPtr->height / 2);
|
||
+ y1i = y2 = buttonY + (buttonPtr->height / 2);
|
||
x2 = x1 + (LEVELWIDTH(treePtr->level) + LEVELWIDTH(treePtr->level + 1)) / 2;
|
||
|
||
if ((treePtr->parentPtr != NULL) && (hboxPtr->lineWidth > 0)) {
|
||
@@ -4883,17 +4883,17 @@
|
||
* For every node except root, draw a horizontal line from
|
||
* the vertical bar to the middle of the icon.
|
||
*/
|
||
- XDrawLine(hboxPtr->display, drawable, hboxPtr->lineGC, x1, y1, x2, y2);
|
||
+ XDrawLine(hboxPtr->display, drawable, hboxPtr->lineGC, x1, y1i, x2, y2);
|
||
}
|
||
if ((entryPtr->flags & ENTRY_OPEN) && (hboxPtr->lineWidth > 0)) {
|
||
/*
|
||
* Entry is open, draw vertical line.
|
||
*/
|
||
- y2 = y1 + entryPtr->lineHeight;
|
||
+ y2 = y1i + entryPtr->lineHeight;
|
||
if (y2 > Tk_Height(hboxPtr->tkwin)) {
|
||
y2 = Tk_Height(hboxPtr->tkwin); /* Clip line at window border. */
|
||
}
|
||
- XDrawLine(hboxPtr->display, drawable, hboxPtr->lineGC, x2, y1, x2, y2);
|
||
+ XDrawLine(hboxPtr->display, drawable, hboxPtr->lineGC, x2, y1i, x2, y2);
|
||
}
|
||
if ((entryPtr->flags & ENTRY_BUTTON) && (treePtr->parentPtr != NULL)) {
|
||
/*
|
||
@@ -5506,7 +5506,7 @@
|
||
return Tk_ConfigureInfo(interp, hboxPtr->tkwin, buttonConfigSpecs,
|
||
(char *)hboxPtr, argv[0], 0);
|
||
}
|
||
- if (Tk_ConfigureWidget(hboxPtr->interp, hboxPtr->tkwin, buttonConfigSpecs,
|
||
+ if (Blt_ConfigureWidget(hboxPtr->interp, hboxPtr->tkwin, buttonConfigSpecs,
|
||
argc, argv, (char *)hboxPtr, TK_CONFIG_ARGV_ONLY) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
}
|
||
--- a/generic/bltBusy.c
|
||
+++ b/generic/bltBusy.c
|
||
@@ -418,7 +418,7 @@
|
||
Tk_Cursor oldCursor;
|
||
|
||
oldCursor = busyPtr->cursor;
|
||
- if (Tk_ConfigureWidget(interp, busyPtr->tkRef, configSpecs, argc, argv,
|
||
+ if (Blt_ConfigureWidget(interp, busyPtr->tkRef, configSpecs, argc, argv,
|
||
(char *)busyPtr, 0) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
}
|
||
--- a/generic/bltConfig.c
|
||
+++ b/generic/bltConfig.c
|
||
@@ -1573,7 +1573,7 @@
|
||
Blt_Free(tempName);
|
||
|
||
Tk_SetClass(tkwin, className);
|
||
- result = Tk_ConfigureWidget(interp, tkwin, specsPtr, argc, argv, widgRec,
|
||
+ result = Blt_ConfigureWidget(interp, tkwin, specsPtr, argc, argv, widgRec,
|
||
flags);
|
||
if (isTemporary) {
|
||
Tk_DestroyWindow(tkwin);
|
||
--- a/generic/bltTed.c
|
||
+++ b/generic/bltTed.c
|
||
@@ -826,7 +826,7 @@
|
||
GC newGC;
|
||
unsigned long gcMask;
|
||
|
||
- if (Tk_ConfigureWidget(tedPtr->interp, tedPtr->tkwin, configSpecs,
|
||
+ if (Blt_ConfigureWidget(tedPtr->interp, tedPtr->tkwin, configSpecs,
|
||
argc, argv, (char *)tedPtr, flags) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
}
|
||
--- a/generic/bltGrAxis.c
|
||
+++ b/generic/bltGrAxis.c
|
||
@@ -3448,7 +3448,7 @@
|
||
return Tk_ConfigureInfo(graphPtr->interp, graphPtr->tkwin, configSpecs,
|
||
(char *)axisPtr, argv[0], flags);
|
||
}
|
||
- if (Tk_ConfigureWidget(graphPtr->interp, graphPtr->tkwin, configSpecs,
|
||
+ if (Blt_ConfigureWidget(graphPtr->interp, graphPtr->tkwin, configSpecs,
|
||
argc, argv, (char *)axisPtr, flags) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
}
|
||
--- a/generic/bltHtext.c
|
||
+++ b/generic/bltHtext.c
|
||
@@ -40,6 +40,13 @@
|
||
* of the virtual text.
|
||
*/
|
||
|
||
+/*
|
||
+ * the htext widget is broken in tk8.5.6 as
|
||
+ * Tk_ConfigureWidget no longer supports
|
||
+ * queries of changed options. Need to migrate to Tk_SetOptions
|
||
+ * instead hack a wrapper Blt_ConfigureWidget
|
||
+ */
|
||
+
|
||
#include "bltInt.h"
|
||
|
||
#ifndef NO_HTEXT
|
||
@@ -338,7 +345,7 @@
|
||
TK_CONFIG_DONT_SET_DEFAULT, &heightOption},
|
||
{TK_CONFIG_CUSTOM, "-linespacing", "lineSpacing", "LineSpacing",
|
||
DEF_HTEXT_LINE_SPACING, Tk_Offset(HText, leader),
|
||
- TK_CONFIG_DONT_SET_DEFAULT, &bltDistanceOption},
|
||
+ TK_CONFIG_DONT_SET_DEFAULT, &bltDistanceOption},
|
||
{TK_CONFIG_CUSTOM, "-maxheight", "maxHeight", "MaxHeight",
|
||
DEF_HTEXT_MAX_HEIGHT, Tk_Offset(HText, maxHeight),
|
||
TK_CONFIG_DONT_SET_DEFAULT, &bltDistanceOption},
|
||
@@ -2841,9 +2848,15 @@
|
||
Tk_GetFontMetrics(htPtr->font, &fontMetrics);
|
||
if ((segPtr->textEnd < htPtr->selFirst) ||
|
||
(segPtr->textStart > htPtr->selLast)) { /* No selected text */
|
||
+#ifdef TK_DRAWCHARS_ANLGE
|
||
+ Tk_DrawChars(htPtr->display, draw, htPtr->drawGC, htPtr->font,
|
||
+ htPtr->charArr + segPtr->textStart, textLength - 1,
|
||
+ x, y + linePtr->baseline, 0.);
|
||
+#else
|
||
Tk_DrawChars(htPtr->display, draw, htPtr->drawGC, htPtr->font,
|
||
htPtr->charArr + segPtr->textStart, textLength - 1,
|
||
x, y + linePtr->baseline);
|
||
+#endif
|
||
return;
|
||
}
|
||
/*
|
||
@@ -2872,9 +2885,15 @@
|
||
Tk_MeasureChars(htPtr->font, htPtr->charArr + segPtr->textStart,
|
||
nChars, 10000, DEF_TEXT_FLAGS, &lastX);
|
||
lastX += x;
|
||
+#ifdef TK_DRAWCHARS_ANGLE
|
||
+ Tk_DrawChars(htPtr->display, draw, htPtr->drawGC, htPtr->font,
|
||
+ htPtr->charArr + segPtr->textStart, nChars, x,
|
||
+ y + linePtr->baseline, 0.);
|
||
+#else
|
||
Tk_DrawChars(htPtr->display, draw, htPtr->drawGC, htPtr->font,
|
||
htPtr->charArr + segPtr->textStart, nChars, x,
|
||
y + linePtr->baseline);
|
||
+#endif
|
||
curPos = selStart;
|
||
}
|
||
if (selLength > 0) { /* The selection itself */
|
||
@@ -2890,16 +2909,28 @@
|
||
lastX, y + linePtr->baseline - fontMetrics.ascent,
|
||
width, fontMetrics.linespace, htPtr->selBorderWidth,
|
||
TK_RELIEF_RAISED);
|
||
+#ifdef TK_DRAWCHARS_ANGLE
|
||
+ Tk_DrawChars(htPtr->display, draw, htPtr->selectGC,
|
||
+ htPtr->font, htPtr->charArr + selStart, selLength,
|
||
+ lastX, y + linePtr->baseline, 0.);
|
||
+#else
|
||
Tk_DrawChars(htPtr->display, draw, htPtr->selectGC,
|
||
htPtr->font, htPtr->charArr + selStart, selLength,
|
||
lastX, y + linePtr->baseline);
|
||
+#endif
|
||
lastX = nextX;
|
||
curPos = selStart + selLength;
|
||
}
|
||
nChars = segPtr->textEnd - curPos;
|
||
if (nChars > 0) { /* Text following the selection */
|
||
+#ifdef TK_DRAWCHARS_ANGLE
|
||
+ Tk_DrawChars(htPtr->display, draw, htPtr->drawGC, htPtr->font,
|
||
+ htPtr->charArr + curPos, nChars - 1,
|
||
+ lastX, y + linePtr->baseline, 0.);
|
||
+#else
|
||
Tk_DrawChars(htPtr->display, draw, htPtr->drawGC, htPtr->font,
|
||
htPtr->charArr + curPos, nChars - 1, lastX, y + linePtr->baseline);
|
||
+#endif
|
||
}
|
||
}
|
||
|
||
@@ -3055,18 +3086,21 @@
|
||
XFillRectangle(display, pixmap, htPtr->fillGC, 0, 0, width, height);
|
||
}
|
||
|
||
-
|
||
- if (! htPtr->lineArr) return;
|
||
- if (deltaY >= 0) {
|
||
+ /* handle null lineArr */
|
||
+ if (htPtr->arraySize > 0 && htPtr->nLines > 0) {
|
||
+ if (deltaY >= 0) {
|
||
y += htPtr->lineArr[htPtr->first].offset;
|
||
lineNum = htPtr->first;
|
||
lastY = 0;
|
||
- } else {
|
||
+ } else {
|
||
y += htPtr->lineArr[htPtr->last].offset;
|
||
lineNum = htPtr->last;
|
||
lastY = height;
|
||
+ }
|
||
+ forceCopy = 0;
|
||
+ } else {
|
||
+ htPtr->last = htPtr->first - 1;
|
||
}
|
||
- forceCopy = 0;
|
||
|
||
/* Draw each line */
|
||
for (i = htPtr->first; i <= htPtr->last; i++) {
|
||
@@ -3365,7 +3399,8 @@
|
||
* The page is always draw at full width and the viewport will clip
|
||
* the text.
|
||
*/
|
||
- if ((htPtr->first != oldFirst) || (htPtr->last != oldLast)) {
|
||
+ if ((htPtr->first != oldFirst) || (htPtr->last != oldLast)
|
||
+ || htPtr->flags & TEXT_DIRTY ) {
|
||
int offset;
|
||
int i;
|
||
int first, last;
|
||
@@ -3383,23 +3418,26 @@
|
||
}
|
||
if (! htPtr->lineArr) return;
|
||
|
||
- for (i = first; i <= last; i++) {
|
||
+
|
||
+ if (htPtr->arraySize > 0 && htPtr->nLines > 0) {
|
||
+ for (i = first; i <= last; i++) {
|
||
offset = htPtr->lineArr[i].offset;
|
||
for (linkPtr = Blt_ChainFirstLink(htPtr->lineArr[i].chainPtr);
|
||
- linkPtr != NULL; linkPtr = Blt_ChainNextLink(linkPtr)) {
|
||
- winPtr = Blt_ChainGetValue(linkPtr);
|
||
- if (winPtr->tkwin != NULL) {
|
||
- MoveEmbeddedWidget(winPtr, offset);
|
||
- winPtr->flags &= ~WIDGET_VISIBLE;
|
||
- }
|
||
+ linkPtr != NULL; linkPtr = Blt_ChainNextLink(linkPtr)) {
|
||
+ winPtr = Blt_ChainGetValue(linkPtr);
|
||
+ if (winPtr->tkwin != NULL) {
|
||
+ MoveEmbeddedWidget(winPtr, offset);
|
||
+ winPtr->flags &= ~WIDGET_VISIBLE;
|
||
+ }
|
||
}
|
||
+ }
|
||
}
|
||
- }
|
||
- DrawPage(htPtr, deltaY);
|
||
- SendBogusEvent(tkwin);
|
||
+ DrawPage(htPtr, deltaY);
|
||
+ SendBogusEvent(tkwin);
|
||
|
||
- /* Reset flags */
|
||
- htPtr->flags &= ~TEXT_DIRTY;
|
||
+ /* Reset flags */
|
||
+ htPtr->flags &= ~TEXT_DIRTY;
|
||
+ }
|
||
}
|
||
|
||
/* Selection Procedures */
|
||
@@ -3919,7 +3957,7 @@
|
||
if (winPtr == NULL) {
|
||
return TCL_ERROR;
|
||
}
|
||
- if (Tk_ConfigureWidget(interp, htPtr->tkwin, widgetConfigSpecs,
|
||
+ if (Blt_ConfigureWidget(interp, htPtr->tkwin, widgetConfigSpecs,
|
||
argc - 3, argv + 3, (char *)winPtr, 0) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
}
|
||
@@ -4089,8 +4127,13 @@
|
||
return Tk_ConfigureInfo(interp, htPtr->tkwin, specsPtr, itemPtr,
|
||
argv[2], 0);
|
||
}
|
||
- if (Tk_ConfigureWidget(interp, htPtr->tkwin, specsPtr, argc - 2,
|
||
- argv + 2, itemPtr, TK_CONFIG_ARGV_ONLY) != TCL_OK) {
|
||
+ if (Blt_ConfigureWidget(interp, htPtr->tkwin, specsPtr, argc - 2,
|
||
+ argv + 2, itemPtr, TK_CONFIG_ARGV_ONLY) != TCL_OK) {
|
||
+
|
||
+ /*
|
||
+ * in 8.5 cant tell if in option was modified
|
||
+ * supposed to convert to Tk_SetOptions
|
||
+ */
|
||
return TCL_ERROR;
|
||
}
|
||
if (itemPtr == (char *)htPtr) {
|
||
@@ -4487,7 +4530,7 @@
|
||
#ifdef ITCL_NAMESPACES
|
||
Itk_SetWidgetCommand(htPtr->tkwin, htPtr->cmdToken);
|
||
#endif
|
||
- if ((Tk_ConfigureWidget(interp, htPtr->tkwin, configSpecs, argc - 2,
|
||
+ if ((Blt_ConfigureWidget(interp, htPtr->tkwin, configSpecs, argc - 2,
|
||
argv + 2, (char *)htPtr, 0) != TCL_OK) ||
|
||
(ConfigureText(interp, htPtr) != TCL_OK)) {
|
||
Tk_DestroyWindow(htPtr->tkwin);
|
||
--- a/generic/bltWinDraw.c
|
||
+++ b/generic/bltWinDraw.c
|
||
@@ -1647,8 +1647,13 @@
|
||
if (drawable == None) {
|
||
return;
|
||
}
|
||
+#ifdef TK_DRAWCHARS_ANGLE
|
||
+ Tk_DrawChars(display, drawable, gc, (Tk_Font)gc->font, string, length,
|
||
+ x, y, 0.);
|
||
+#else
|
||
Tk_DrawChars(display, drawable, gc, (Tk_Font)gc->font, string, length,
|
||
x, y);
|
||
+#endif
|
||
}
|
||
|
||
static void
|
||
--- a/generic/bltGrMarker.c
|
||
+++ b/generic/bltGrMarker.c
|
||
@@ -4313,7 +4313,7 @@
|
||
/* Save the old marker. */
|
||
oldName = markerPtr->name;
|
||
under = markerPtr->drawUnder;
|
||
- if (Tk_ConfigureWidget(interp, graphPtr->tkwin,
|
||
+ if (Blt_ConfigureWidget(interp, graphPtr->tkwin,
|
||
markerPtr->classPtr->configSpecs, nOpts, options,
|
||
(char *)markerPtr, flags) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
--- a/generic/bltBitmap.c
|
||
+++ b/generic/bltBitmap.c
|
||
@@ -917,7 +917,7 @@
|
||
info.padLeft = info.padRight = 0;
|
||
info.padTop = info.padBottom = 0;
|
||
info.font = (Tk_Font)NULL; /* Initialized by Tk_ConfigureWidget */
|
||
- if (Tk_ConfigureWidget(interp, tkwin, composeConfigSpecs,
|
||
+ if (Blt_ConfigureWidget(interp, tkwin, composeConfigSpecs,
|
||
argc - 4, argv + 4, (char *)&info, 0) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
}
|
||
@@ -1027,7 +1027,7 @@
|
||
/* Initialize info and then process flags */
|
||
info.rotate = 0.0; /* No rotation by default */
|
||
info.scale = 1.0; /* No scaling by default */
|
||
- if (Tk_ConfigureWidget(interp, dataPtr->tkwin, defineConfigSpecs,
|
||
+ if (Blt_ConfigureWidget(interp, dataPtr->tkwin, defineConfigSpecs,
|
||
argc - 4, argv + 4, (char *)&info, 0) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
}
|
||
--- a/generic/bltTabnotebook.c
|
||
+++ b/generic/bltTabnotebook.c
|
||
@@ -2766,7 +2766,7 @@
|
||
GC newGC;
|
||
|
||
lastNotebookInstance = nbPtr;
|
||
- if (Tk_ConfigureWidget(interp, nbPtr->tkwin, configSpecs, argc, argv,
|
||
+ if (Blt_ConfigureWidget(interp, nbPtr->tkwin, configSpecs, argc, argv,
|
||
(char *)nbPtr, flags) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
}
|
||
@@ -3691,7 +3691,7 @@
|
||
}
|
||
Tcl_Preserve(tabPtr);
|
||
lastNotebookInstance = nbPtr;
|
||
- result = Tk_ConfigureWidget(interp, nbPtr->tkwin, tabConfigSpecs,
|
||
+ result = Blt_ConfigureWidget(interp, nbPtr->tkwin, tabConfigSpecs,
|
||
nOpts, options, (char *)tabPtr, TK_CONFIG_ARGV_ONLY);
|
||
if (result == TCL_OK) {
|
||
result = ConfigureTab(nbPtr, tabPtr);
|
||
--- a/generic/bltContainer.c
|
||
+++ b/generic/bltContainer.c
|
||
@@ -1193,7 +1193,7 @@
|
||
GC newGC;
|
||
int width, height;
|
||
|
||
- if (Tk_ConfigureWidget(interp, cntrPtr->tkwin, configSpecs, argc, argv,
|
||
+ if (Blt_ConfigureWidget(interp, cntrPtr->tkwin, configSpecs, argc, argv,
|
||
(char *)cntrPtr, flags) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
}
|
||
--- a/generic/bltTabset.c
|
||
+++ b/generic/bltTabset.c
|
||
@@ -3163,7 +3163,7 @@
|
||
XColor *activeColor; /* Active foreground. */
|
||
|
||
tabSet = setPtr;
|
||
- if (Tk_ConfigureWidget(interp, setPtr->tkwin, configSpecs, argc, argv,
|
||
+ if (Blt_ConfigureWidget(interp, setPtr->tkwin, configSpecs, argc, argv,
|
||
(char *)setPtr, flags) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
}
|
||
@@ -4452,7 +4452,7 @@
|
||
}
|
||
tabSet = setPtr;
|
||
Tcl_Preserve(tabPtr);
|
||
- result = Tk_ConfigureWidget(interp, setPtr->tkwin, tabConfigSpecs,
|
||
+ result = Blt_ConfigureWidget(interp, setPtr->tkwin, tabConfigSpecs,
|
||
nOpts, options, (char *)tabPtr, TK_CONFIG_ARGV_ONLY);
|
||
if (result == TCL_OK || nOpts>=2) {
|
||
result = ConfigureTab(setPtr, tabPtr);
|
||
--- a/generic/bltGrGrid.c
|
||
+++ b/generic/bltGrGrid.c
|
||
@@ -368,7 +368,7 @@
|
||
return Tk_ConfigureInfo(interp, graphPtr->tkwin, configSpecs,
|
||
(char *)gridPtr, argv[3], flags);
|
||
}
|
||
- if (Tk_ConfigureWidget(graphPtr->interp, graphPtr->tkwin, configSpecs,
|
||
+ if (Blt_ConfigureWidget(graphPtr->interp, graphPtr->tkwin, configSpecs,
|
||
argc - 3, argv + 3, (char *)gridPtr, flags) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
}
|
||
--- a/generic/tkButton.c
|
||
+++ b/generic/tkButton.c
|
||
@@ -1721,7 +1721,7 @@
|
||
oldSelVar = (butPtr->selVarName?strdup(butPtr->selVarName):NULL);
|
||
}
|
||
|
||
- if (Tk_ConfigureWidget(interp, butPtr->tkwin, configSpecs,
|
||
+ if (Blt_ConfigureWidget(interp, butPtr->tkwin, configSpecs,
|
||
argc, argv, (char *)butPtr, flags) != TCL_OK) {
|
||
if (oldTextVar) ckfree(oldTextVar);
|
||
if (oldTextVar) ckfree(oldSelVar);
|
||
--- a/generic/bltGrElem.c
|
||
+++ b/generic/bltGrElem.c
|
||
@@ -1699,7 +1699,7 @@
|
||
search.x = x;
|
||
search.y = y;
|
||
|
||
- if (Tk_ConfigureWidget(interp, graphPtr->tkwin, closestSpecs, i - 6,
|
||
+ if (Blt_ConfigureWidget(interp, graphPtr->tkwin, closestSpecs, i - 6,
|
||
argv + 6, (char *)&search, TK_CONFIG_ARGV_ONLY) != TCL_OK) {
|
||
return TCL_ERROR; /* Error occurred processing an option. */
|
||
}
|
||
@@ -1854,7 +1854,7 @@
|
||
return Tk_ConfigureInfo(interp, graphPtr->tkwin,
|
||
elemPtr->specsPtr, (char *)elemPtr, options[0], flags);
|
||
}
|
||
- if (Tk_ConfigureWidget(interp, graphPtr->tkwin, elemPtr->specsPtr,
|
||
+ if (Blt_ConfigureWidget(interp, graphPtr->tkwin, elemPtr->specsPtr,
|
||
numOpts, options, (char *)elemPtr, flags) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
}
|
||
--- a/generic/bltTable.c
|
||
+++ b/generic/bltTable.c
|
||
@@ -1201,7 +1201,7 @@
|
||
oldRowSpan = entryPtr->row.span;
|
||
oldColSpan = entryPtr->column.span;
|
||
|
||
- if (Tk_ConfigureWidget(interp, entryPtr->tkwin, entryConfigSpecs,
|
||
+ if (Blt_ConfigureWidget(interp, entryPtr->tkwin, entryConfigSpecs,
|
||
argc, argv, (char *)entryPtr, TK_CONFIG_ARGV_ONLY) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
}
|
||
@@ -1553,7 +1553,7 @@
|
||
return Tk_ConfigureInfo(tablePtr->interp, tablePtr->tkwin,
|
||
infoPtr->configSpecs, (char *)rcPtr, argv[0], 0);
|
||
} else {
|
||
- if (Tk_ConfigureWidget(tablePtr->interp, tablePtr->tkwin,
|
||
+ if (Blt_ConfigureWidget(tablePtr->interp, tablePtr->tkwin,
|
||
infoPtr->configSpecs, argc, argv, (char *)rcPtr,
|
||
TK_CONFIG_ARGV_ONLY) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
@@ -1578,7 +1578,7 @@
|
||
}
|
||
rcPtr = GetRowColumn(infoPtr, n);
|
||
assert(rcPtr);
|
||
- if (Tk_ConfigureWidget(tablePtr->interp, tablePtr->tkwin,
|
||
+ if (Blt_ConfigureWidget(tablePtr->interp, tablePtr->tkwin,
|
||
infoPtr->configSpecs, argc, argv, (char *)rcPtr,
|
||
TK_CONFIG_ARGV_ONLY) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
@@ -1861,7 +1861,7 @@
|
||
return Tk_ConfigureInfo(interp, tablePtr->tkwin, tableConfigSpecs,
|
||
(char *)tablePtr, argv[0], 0);
|
||
}
|
||
- if (Tk_ConfigureWidget(interp, tablePtr->tkwin, tableConfigSpecs,
|
||
+ if (Blt_ConfigureWidget(interp, tablePtr->tkwin, tableConfigSpecs,
|
||
argc, argv, (char *)tablePtr, TK_CONFIG_ARGV_ONLY) != TCL_OK) {
|
||
return TCL_ERROR;
|
||
}
|
||
@@ -2198,7 +2198,7 @@
|
||
}
|
||
}
|
||
if (argc > 0) {
|
||
- result = Tk_ConfigureWidget(tablePtr->interp, entryPtr->tkwin,
|
||
+ result = Blt_ConfigureWidget(tablePtr->interp, entryPtr->tkwin,
|
||
entryConfigSpecs, argc, argv, (char *)entryPtr,
|
||
TK_CONFIG_ARGV_ONLY);
|
||
}
|