Bug# 38 baseConvert

Dar Scott dsc at swcp.com
Wed Dec 10 15:14:39 EST 2003


On Wednesday, December 10, 2003, at 05:34 AM, Wouter wrote:

>>> put baseconvert("-3509652390",10,16) --> -D1310BA6  (wow again)
>>
>> This is correct in a pure base interpretation, but creates a strange
>> equality when viewed with the above result.

I was thinking of the problem that D1310BA6 = -D1310BA6 by transitivity 
of earlier results.

>
> Then shouldn't it be:
>    baseconvert("-785314906",10,16) --> D1310BA6
>    baseconvert("3509652390",10,16) --> 2ECEF45A
> and not the other way around ?

The first case assumes the value is put into a signed 32-bit (or 
greater) variable.  The lowest 32 bits of the variable is reinterpreted 
as unsigned 32-bit and then converted to hex.

In an extended baseConvert() this might be done with one of these:

     baseConvert("-785314906",10,16,"S32","U32")
     baseConvert("-785314906",10,16,"S48","U32")

I don't recognize a common interpretation in the second one.

>> For the most part, I use binaryEncode() and binaryDecode() for these.
>
> But these function also should be overhauled as to make the results 
> uniform over all platforms.

Yes.  There is a bugzilla enhancement request that adds portable 
formats, but leaves the host dependent ones for legacy.

> I am also dreaming of things like this:
>     get "D1310BA6"  <hex>xOr   "4B7A70E9"

What about this?

      get u32("xD1310BA6") bitXOR u32("x4B7A70E9")
      get hexXOR("B1310BA6","4B7A70E9")

Or something similar.  This could be done with no changes.

Dar



More information about the use-livecode mailing list