On Sunday, 17 March 2013 at 18:36:17 UTC, bioinfornatics wrote:
On Friday, 15 March 2013 at 16:40:26 UTC, Andrea Fontana wrote:
On Friday, 15 March 2013 at 16:11:38 UTC, bioinfornatics wrote:
On Friday, 15 March 2013 at 14:40:17 UTC, Andrea Fontana
wrote:
On Friday, 15 March 2013 at 14:31:43 UTC, bioinfornatics
wrote:
Dear,
By using CTFE I try to get a generic range to read array or
a file as a phobos range. code hosted here:
http://dpaste.dzfl.pl/1f2bcf39
that works fine for array but for a File instance .eof seem
to not return true a right time.
Soemone could say what happen ?
Thanks
Have you tried to cache front() result and read next block
on popFront()?
that is ok. Just missed the \n the followed code should work
http://dpaste.dzfl.pl/1f2bcf39
You are welcome to take it :)
int[] a = [ 0, 1, 1, 2, 3, 5, 8 ];
std.file.write("/tmp/filename", a);
File f = File("/tmp/filename", "r");
auto r = GenericRange!File(f,1);
r.filter!"a.length > 0 && a[0] != 0"().writeln;
output:
[[0], [0], [0], [0], [0], [0]]
but i think output expected is:
[[1], [1], [2], [3], [5], [8]]
Caching front() and reading buffer from popFront() did the
trick for me.
As you said that do not works i update the code with some
unittest could you please to share your version ? you can use
fork from dpast -> http://dpaste.dzfl.pl/1f2bcf39e. Thanks
Your code works if you use .writeln instead of .array. This why
*it seems* that struct member "U buffer" is returned by reference.
Check this. It passes unittest.
http://dpaste.dzfl.pl/828f7cc4
I move buffer inside popFront function, so "value = rawWrite(..)"
assign every time a reference to a different "buffer". In your
code it returns always the same member variable so, output array
was an array of 8 identical reference to last read value (e.g.
[8]) Maybe you can achieve the same in other way (for example
using idup?).
I hope it works.