diff options
| author | jan.nijtmans <nijtmans@users.sourceforge.net> | 2022-11-20 20:14:07 (GMT) |
|---|---|---|
| committer | jan.nijtmans <nijtmans@users.sourceforge.net> | 2022-11-20 20:14:07 (GMT) |
| commit | a53281f50bff09718a1fd6b0bc5b772a076671ca (patch) | |
| tree | 45fe8a2fc317e1f897165e2f86c57fa49ecbb222 /generic/tclLink.c | |
| parent | bfdd211de9210e8b9cf5af6cf3aa03a4698ef0ee (diff) | |
| parent | 43d67c651c26eb2aa1b324c742047ca0a0c45d0e (diff) | |
| download | tcl-a53281f50bff09718a1fd6b0bc5b772a076671ca.zip tcl-a53281f50bff09718a1fd6b0bc5b772a076671ca.tar.gz tcl-a53281f50bff09718a1fd6b0bc5b772a076671ca.tar.bz2 | |
Rebase to latest 8.7
Diffstat (limited to 'generic/tclLink.c')
| -rw-r--r-- | generic/tclLink.c | 54 |
1 files changed, 6 insertions, 48 deletions
diff --git a/generic/tclLink.c b/generic/tclLink.c index 1973067..cd2c731 100644 --- a/generic/tclLink.c +++ b/generic/tclLink.c @@ -526,56 +526,14 @@ GetUWide( Tcl_Obj *objPtr, Tcl_WideUInt *uwidePtr) { - Tcl_WideInt *widePtr = (Tcl_WideInt *) uwidePtr; - void *clientData; - int type, intValue; - - if (Tcl_GetNumberFromObj(NULL, objPtr, &clientData, &type) == TCL_OK) { - if (type == TCL_NUMBER_INT) { - *widePtr = *((const Tcl_WideInt *) clientData); - return (*widePtr < 0); - } else if (type == TCL_NUMBER_BIG) { - mp_int *numPtr = (mp_int *)clientData; - Tcl_WideUInt value = 0; - union { - Tcl_WideUInt value; - unsigned char bytes[sizeof(Tcl_WideUInt)]; - } scratch; - size_t numBytes; - unsigned char *bytes = scratch.bytes; - - if (numPtr->sign || (MP_OKAY != mp_to_ubin(numPtr, - bytes, sizeof(Tcl_WideUInt), &numBytes))) { - /* - * If the sign bit is set (a negative value) or if the value - * can't possibly fit in the bits of an unsigned wide, there's - * no point in doing further conversion. - */ - return 1; - } -#ifndef WORDS_BIGENDIAN - while (numBytes-- > 0) { - value = (value << CHAR_BIT) | *bytes++; - } -#else /* WORDS_BIGENDIAN */ - /* - * Big-endian can read the value directly. - */ - value = scratch.value; -#endif /* WORDS_BIGENDIAN */ - *uwidePtr = value; - return 0; - } - } - - /* - * Evil edge case fallback. - */ + if (Tcl_GetWideUIntFromObj(NULL, objPtr, uwidePtr) != TCL_OK) { + int intValue; - if (GetInvalidIntFromObj(objPtr, &intValue) != TCL_OK) { - return 1; + if (GetInvalidIntFromObj(objPtr, &intValue) != TCL_OK) { + return 1; + } + *uwidePtr = intValue; } - *uwidePtr = intValue; return 0; } |
