[Issue 3508] New: hasLength is broken for length defined as function
d-bugmail at puremagic.com
d-bugmail at puremagic.com
Sat Nov 14 12:00:36 PST 2009
http://d.puremagic.com/issues/show_bug.cgi?id=3508
Summary: hasLength is broken for length defined as function
Product: D
Version: 2.036
Platform: Other
OS/Version: Linux
Status: NEW
Severity: normal
Priority: P2
Component: Phobos
AssignedTo: nobody at puremagic.com
ReportedBy: k-foley at onu.edu
--- Comment #0 from Kyle Foley <k-foley at onu.edu> 2009-11-14 12:00:35 PST ---
import std.stdio;
struct Test1 { ulong length(); }
struct Test2 { ulong length; }
struct Test3 { string length; }
/* Definition from std.range
template hasLength(R)
{
enum bool hasLength = is(typeof(R.init.length) : ulong);
}
*/
template hasLength(R)
{
enum bool hasLength = is(typeof({
auto r = R.init;
auto l = r.length;
static assert( is(typeof(l) : ulong) );
}()));
}
int main(string[] args)
{
writeln( std.range.hasLength!(Test1) ); // false
writeln( std.range.hasLength!(Test2) ); // true
writeln( std.range.hasLength!(Test3) ); // false
writeln( test.hasLength!(Test1) ); // true
writeln( test.hasLength!(Test2) ); // true
writeln( test.hasLength!(Test3) ); // false
return 0;
}
---
I included my proposed fix as test.hasLength.
--
Configure issuemail: http://d.puremagic.com/issues/userprefs.cgi?tab=email
------- You are receiving this mail because: -------
More information about the Digitalmars-d-bugs
mailing list