Vector: Use opEquals if defined to compare items
This commit is contained in:
parent
c73e704421
commit
b3f4ea572e
@ -6,7 +6,7 @@ os:
|
|||||||
language: d
|
language: d
|
||||||
|
|
||||||
d:
|
d:
|
||||||
- dmd-2.072.1
|
- dmd-2.072.2
|
||||||
- dmd-2.071.2
|
- dmd-2.071.2
|
||||||
|
|
||||||
env:
|
env:
|
||||||
|
@ -27,7 +27,7 @@ helper functions).
|
|||||||
|
|
||||||
### Supported compilers
|
### Supported compilers
|
||||||
|
|
||||||
* dmd 2.072.1
|
* dmd 2.072.2
|
||||||
* dmd 2.071.2
|
* dmd 2.071.2
|
||||||
|
|
||||||
### Current status
|
### Current status
|
||||||
|
@ -21,12 +21,25 @@ import tanya.memory;
|
|||||||
|
|
||||||
version (unittest)
|
version (unittest)
|
||||||
{
|
{
|
||||||
struct TestA
|
struct SWithDtor
|
||||||
{
|
{
|
||||||
|
bool opEquals(ref SWithDtor that)
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
~this() @nogc
|
~this() @nogc
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
struct SConstEquals
|
||||||
|
{
|
||||||
|
bool opEquals(in ref SConstEquals that) const
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Defines the container's primary range.
|
// Defines the container's primary range.
|
||||||
@ -387,7 +400,7 @@ struct Vector(T)
|
|||||||
/**
|
/**
|
||||||
* Destroys this $(D_PSYMBOL Vector).
|
* Destroys this $(D_PSYMBOL Vector).
|
||||||
*/
|
*/
|
||||||
~this()
|
~this() @trusted
|
||||||
{
|
{
|
||||||
static if (hasElaborateDestructor!T)
|
static if (hasElaborateDestructor!T)
|
||||||
{
|
{
|
||||||
@ -404,7 +417,7 @@ struct Vector(T)
|
|||||||
|
|
||||||
private unittest
|
private unittest
|
||||||
{
|
{
|
||||||
auto v = Vector!TestA(); // Destructor can destroy empty vectors.
|
auto v = Vector!SWithDtor(); // Destructor can destroy empty vectors.
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -810,21 +823,44 @@ struct Vector(T)
|
|||||||
/**
|
/**
|
||||||
* Comparison for equality.
|
* Comparison for equality.
|
||||||
*
|
*
|
||||||
* Params:
|
* Params: o = The vector to compare with.
|
||||||
* o = The vector to compare with.
|
|
||||||
*
|
*
|
||||||
* Returns: $(D_KEYWORD true) if the vectors are equal, $(D_KEYWORD false)
|
* Returns: $(D_KEYWORD true) if the vectors are equal, $(D_KEYWORD false)
|
||||||
* otherwise.
|
* otherwise.
|
||||||
*/
|
*/
|
||||||
bool opEquals(typeof(this) v) const
|
bool opEquals()(auto ref typeof(this) v) @trusted
|
||||||
{
|
{
|
||||||
return opEquals(v);
|
if (length_ != v.length_)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
const T* end = vector + length_;
|
||||||
|
for (T* v1 = vector, v2 = v.vector; v1 != end; ++v1, ++v2)
|
||||||
|
{
|
||||||
|
if (*v1 != *v2)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Ditto.
|
/// Ditto.
|
||||||
bool opEquals(ref typeof(this) v) const @trusted
|
bool opEquals()(in auto ref typeof(this) v) const @trusted
|
||||||
{
|
{
|
||||||
return vector[0 .. length_] == v.vector[0 .. v.length_];
|
if (length_ != v.length_)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
const T* end = vector + length_;
|
||||||
|
for (const(T)* v1 = vector, v2 = v.vector; v1 != end; ++v1, ++v2)
|
||||||
|
{
|
||||||
|
if (*v1 != *v2)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
///
|
///
|
||||||
@ -847,6 +883,21 @@ struct Vector(T)
|
|||||||
assert(v1 == v2);
|
assert(v1 == v2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private unittest
|
||||||
|
{
|
||||||
|
auto v1 = Vector!SConstEquals();
|
||||||
|
auto v2 = Vector!SConstEquals();
|
||||||
|
assert(v1 == v2);
|
||||||
|
|
||||||
|
auto v3 = const Vector!SConstEquals();
|
||||||
|
auto v4 = const Vector!SConstEquals();
|
||||||
|
assert(v3 == v4);
|
||||||
|
|
||||||
|
auto v7 = Vector!SWithDtor();
|
||||||
|
auto v8 = Vector!SWithDtor();
|
||||||
|
assert(v7 == v8);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* $(D_KEYWORD foreach) iteration.
|
* $(D_KEYWORD foreach) iteration.
|
||||||
*
|
*
|
||||||
@ -1192,7 +1243,7 @@ private @nogc unittest
|
|||||||
auto a = Vector!A();
|
auto a = Vector!A();
|
||||||
|
|
||||||
// Test that structs can be members of the vector.
|
// Test that structs can be members of the vector.
|
||||||
static assert(is(typeof(Vector!TestA())));
|
static assert(is(typeof(Vector!SWithDtor())));
|
||||||
}
|
}
|
||||||
|
|
||||||
private @nogc unittest
|
private @nogc unittest
|
||||||
|
Loading…
x
Reference in New Issue
Block a user