D operator overloading

Refresh

November 2018

Views

243 time

3
import std.stdio;

struct Vector2
{
    float x, y;

    this (float x, float y)
    {
        this.x = x;
        this.y = y;
    }

    // vector2 * number
    Vector2 opBinary(string op)(const float rhs)
    if (op == "*")
    {
        auto result = this;
        this *= rhs;
        return this;
    }

    // number * vector2
    Vector2 opBinaryRight(string op)(const float lhs)
    if (op == "*")
    {
        return this.opBinary!(op)(lhs);
    }

    /*
      assignment operators
    */

    // vector2 = vector2
    ref Vector2 opAssign(const ref Vector2 rhs)
    {
        x = rhs.x;
        y = rhs.y;
        return this;
    }

    // vector2 *= number
    ref Vector2 opOpAssign(string op)(const float rhs)
    if (op == "*") {
        x *= rhs;
        y *= rhs;
        return this;
    }
}

unittest
{
    auto first = Vector2(1, 2);
    auto second = Vector2(3, 3);
    auto number = 4.0f;

    Vector2 result = first *= 3;
    assert(result == Vector2(3, 6));
    // BUG *
    // assert(first == Vector2(1, 2));    
}

void main() 
{}

Hi. When I try to compile this small program with -unittest option why does the last assertion fails? Any help would be appreciated. Thanks..

1 answers

5

Почему вы ожидаете, что это пройдет?

first *= 3изменяет first, поэтому он не сохраняет свою первоначальную ценность.

Возможно, вы имели в виду, чтобы написать

Vector2 result = first * 3;

?

Существует также проблема с Vector2 opBinary(string op)(const float rhs)

Эта функция является то , что используется в выражении типа 10 * v. Ваш код изменяет thisв выражении this *= rhs. Эта функция должна быть реализована:

auto result = this;
result *= rhs;
return result;