digitalmars.D.learn - strage heisenbug (has scoped destruction, cannot build closure)
hi.
the following (manually "dustmited" ;-)) code gives the error from subj=20
on git HEAD:
=3D=3D=3D ztest.d =3D=3D=3D
module ztest;
auto streamAsRange(STP) (STP st) {
static struct StreamRange(ST) {
private:
ST strm;
public:
void put (const(ubyte)[] data) { strm.rawWrite(data); }
}
return StreamRange!STP();
}
void zcompress(RO) (RO ro) {
ubyte[1] obuf;
void writeOBuf () {
static if (is(typeof(() {
ubyte[2] b;
ro.put(b);
}))) {
ro.put(obuf);
}
}
writeOBuf();
}
void test () {
import std.stdio;
auto fo =3D File();
zcompress(streamAsRange(fo));
}
void main () {
}
=3D=3D=3D=3D=3D=3D
the strange thing is that this is heisenbug. if i comment out `static if`=20
the module successfully compiles. i.e. changing `zcompress()` to this=20
allows me to compile the code:
=3D=3D=3D
void zcompress(RO) (RO ro) {
ubyte[1] obuf;
void writeOBuf () {
ro.put(obuf);
}
writeOBuf();
}
=3D=3D=3D
so the offending line is `ro.put(b);` (comment it out, and everything is=20
working again).
am i doing something very wrong here, or this is really a compiler bug?=
Mar 02 2015
p.s. well, it's not a heisenbug, 'cause it reproducible. let's say that=20 it's a... very strange bug. ;-)=
Mar 02 2015
p.p.s. sure, i can see where i'm creating a closure. but i can't see how=20 that closure got to IR generator, as it is never executes, there is no=20 need to generate code for it, and it should be removed after checking=20 `static if` condition.=
Mar 02 2015
On Tuesday, 3 March 2015 at 07:26:13 UTC, ketmar wrote:
hi.
the following (manually "dustmited" ;-)) code gives the error
from subj
on git HEAD:
=== ztest.d ===
module ztest;
auto streamAsRange(STP) (STP st) {
static struct StreamRange(ST) {
private:
ST strm;
public:
void put (const(ubyte)[] data) { strm.rawWrite(data); }
}
return StreamRange!STP();
}
void zcompress(RO) (RO ro) {
ubyte[1] obuf;
void writeOBuf () {
static if (is(typeof(() {
ubyte[2] b;
ro.put(b);
}))) {
ro.put(obuf);
}
}
writeOBuf();
}
void test () {
import std.stdio;
auto fo = File();
zcompress(streamAsRange(fo));
}
void main () {
}
======
Reduced further:
----
module ztest;
struct StreamRange {
~this() {}
void put() {}
}
void zcompress(StreamRange ro) {
void writeOBuf() {
enum e = is(typeof({ro.put();}));
ro.put();
}
writeOBuf();
}
void main() {
zcompress(StreamRange());
}
----
Looks like a compiler bug to me.
Mar 03 2015









ketmar <ketmar ketmar.no-ip.org> 