On 14/01/2013 15:52, Jonas Maebe wrote:

On 14 Jan 2013, at 16:44, Martin wrote:

This is casting a "set of bits" (neither signed, nor unsigned - a set is not a number at all) into a number. This only needs to have a definition, if it should cast to signed or unsigned type.

It has to be signed, because otherwise any negative number in the operation would trigger a range check error when it gets converted to a (larger) unsigned type. The nature of the operation that is used afterwards is irrelevant, range checking always operates in exactly the same way when performing a type conversion from one type to another. This is required to have predictable behaviour in a programming language.


not sure if I follow. If "or" performs on a "set of bits" (rather than a number), and a set (not being a number) is neither signed or unsigned, then before the "OR" both operands (independent of being signed or not) will be cast to a set. The result is a set. The set can be converted to either signed or unsigned. The set has no range checking.

  result := bit_set32(a) or bit_set32(b)

If result has also 32 (or more) bits, then no range check error can occur. In the set, the high-bit has no meaning. It is neither part of the (unsigned positive) numer, nor is it sign indicator. This meaning is only applied by casting it to a numeric type.

Same as
var i: set of (b0, b1, b2 .... b31);
signed := integer(i);
unsigned := cardinal(i);


_______________________________________________
fpc-devel maillist  -  fpc-devel@lists.freepascal.org
http://lists.freepascal.org/mailman/listinfo/fpc-devel

Reply via email to