[Issue 6849] New: std.algorithm.remove design
d-bugmail at puremagic.com
d-bugmail at puremagic.com
Tue Oct 25 04:22:20 PDT 2011
http://d.puremagic.com/issues/show_bug.cgi?id=6849
Summary: std.algorithm.remove design
Product: D
Version: D2
Platform: x86
OS/Version: Windows
Status: NEW
Severity: normal
Priority: P2
Component: Phobos
AssignedTo: nobody at puremagic.com
ReportedBy: bearophile_hugs at eml.cc
--- Comment #0 from bearophile_hugs at eml.cc 2011-10-25 04:21:13 PDT ---
A D2 program:
import std.stdio, std.algorithm;
void main() {
dchar[] data = "abcde"d.dup;
writeln(data);
writeln(remove(data, 0));
writeln(data);
writeln(remove(data, 2));
writeln(data);
}
With DMD 2.056beta3 it prints:
abcde
bcde
bcdee
bcee
bceee
Expected output:
abcde
bcde
bcde
bce
bce
Or maybe it's better for remove() to return void, to underline its in-place
nature (this is often done in Python, where functions the modify da in-place
usually return just None, and functions with a name that ends with "ed" create
new data and return it, like the sort/sorted pair):
import std.stdio, std.algorithm;
void main() {
dchar[] data = "abcde"d.dup;
writeln(data);
data.remove(0);
writeln(data);
data.remove(2);
writeln(data);
}
Expected output:
abcde
bcde
bce
This is similar to what happens in Python2:
>>> data = ['a', 'b', 'c', 'd', 'e']
>>> del data[0]
>>> data
['b', 'c', 'd', 'e']
>>> del data[2]
>>> data
['b', 'c', 'e']
--
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