Warn about do nothing expressions?
Barry L.
barry.lapthorn at gmail.com
Fri Mar 28 11:20:16 PDT 2014
I ran this:
import std.stdio;
void main() {
int i = 10;
i = i++;
writeln(i);
}
with DMD32 D Compiler v2.063.2 and got '10'.
And for nothing other than curiousity, this in both VS2012, and
VS2013:
#include <iostream>
int main(int argc, char const *argv[])
{
int i = 10;
i = i++;
std::cout << i << std::endl;
return 0;
}
and got '11', both times.
On Friday, 28 March 2014 at 18:04:41 UTC, Frustrated wrote:
> On Friday, 28 March 2014 at 16:54:49 UTC, Benjamin Thaut wrote:
>> I had a bug which came down to the following line today:
>>
>> m_takeIndex = m_takeIndex++;
>>
>> Actually this line does nothing. m_takeIndex remains at
>> exactly the same value as before (tested with dmd 2.065).
>>
>> Can someone please explain why? And would be suitable to warn
>> about this, if it is correct behaviour?
>>
>> Kind Regards
>> Benjamin Thaut
>
> This should be invalid.
>
> m_takeIndex++;
>
> actually increments the variable.
>
> m_takeIndex = m_takeIndex++; should do exactly the same.
>
> It is a bug. It might be correct in monarch's world but it is
> not logical. I think monarch is just trying to justify the way
> D does it, regardless if D is D is wrong or not.
>
> I imagine what is going on is that D is creating a temp
> variable, assigning it to the local variable, then incrementing
> the temp variable(since++ increments "after" the assignment).
>
> That, or D really is treating that as a nop, which is wrong too.
>
> Test case shows it is probably the first:
>
> int j = 0, i = 0;
> i = j++;
> // i = 0, j = 1
>
> hence D is wrong, Monarch is wrong, etc...
>
> m_takeIndex = m_takeIndex++;
>
> should, given the example above, evaluate to
>
> m_takeIndex = m_takeIndex; (a nop)
> m_takeIndex++; (variable incremented)
>
>
> hence, D is not consistent with itself, which at the very least
> is a bug.
More information about the Digitalmars-d
mailing list