From 3863b1c0eac186a8e9cb66952c457082ef00ac8d Mon Sep 17 00:00:00 2001 From: dkf Date: Wed, 14 May 2003 22:45:10 +0000 Subject: Stopped [format] from demoting wides to ints too easily. [Bug 699060] --- ChangeLog | 5 +++++ generic/tclCmdAH.c | 17 ++++++++++++++--- tests/format.test | 25 ++++++++++++++++++++++++- 3 files changed, 43 insertions(+), 4 deletions(-) diff --git a/ChangeLog b/ChangeLog index 4621888..79ad729 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +2003-05-14 Donal K. Fellows + + * generic/tclCmdAH.c (Tcl_FormatObjCmd): Stop unwarranted demotion + of wide values to longs by formatting of int values. [Bug 699060] + 2003-05-14 Jeff Hobbs * library/encoding/gb2312.enc: copy euc-cn.enc over original diff --git a/generic/tclCmdAH.c b/generic/tclCmdAH.c index 3731974..d4788be 100644 --- a/generic/tclCmdAH.c +++ b/generic/tclCmdAH.c @@ -11,7 +11,7 @@ * See the file "license.terms" for information on usage and redistribution * of this file, and for a DISCLAIMER OF ALL WARRANTIES. * - * RCS: @(#) $Id: tclCmdAH.c,v 1.32 2003/05/05 20:54:38 dgp Exp $ + * RCS: @(#) $Id: tclCmdAH.c,v 1.33 2003/05/14 22:45:12 dkf Exp $ */ #include "tclInt.h" @@ -2256,7 +2256,7 @@ Tcl_FormatObjCmd(dummy, interp, objc, objv) case 'x': case 'X': if (useWide) { - if (Tcl_GetWideIntFromObj(interp, /* INTL: Tcl source. */ + if (Tcl_GetWideIntFromObj(interp, /* INTL: Tcl source. */ objv[objIndex], &wideValue) != TCL_OK) { goto fmtError; } @@ -2264,7 +2264,18 @@ Tcl_FormatObjCmd(dummy, interp, objc, objv) size = 40 + precision; break; } - if (Tcl_GetLongFromObj(interp, /* INTL: Tcl source. */ + if (objv[objIndex]->typePtr == &tclWideIntType) { + /* Operation won't fail; we're typed! */ + Tcl_GetWideIntFromObj(NULL, objv[objIndex], &wideValue); + if (wideValue>ULONG_MAX || wideValue