2017-12-06 17:27:44 +00:00
|
|
|
/*
|
|
|
|
* Copyright 2017 Google Inc.
|
|
|
|
*
|
|
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
|
|
* found in the LICENSE file.
|
|
|
|
*/
|
|
|
|
|
2019-04-23 17:05:21 +00:00
|
|
|
#include "src/core/SkVptr.h"
|
|
|
|
#include "tests/Test.h"
|
2017-12-06 17:27:44 +00:00
|
|
|
|
|
|
|
namespace {
|
|
|
|
|
|
|
|
struct Base {
|
|
|
|
virtual ~Base() = default;
|
|
|
|
virtual size_t val() const = 0;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct SubclassA : public Base {
|
|
|
|
SubclassA(size_t val) : fVal(val) {}
|
|
|
|
|
|
|
|
size_t val() const override { return fVal; }
|
|
|
|
|
|
|
|
size_t fVal;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct SubclassB : public Base {
|
|
|
|
SubclassB() {}
|
|
|
|
|
|
|
|
size_t val() const override { return 42; }
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
DEF_TEST(Vptr, r) {
|
2019-12-11 15:45:01 +00:00
|
|
|
std::unique_ptr<Base> a = std::make_unique<SubclassA>(21),
|
|
|
|
b = std::make_unique<SubclassB>(),
|
|
|
|
c = std::make_unique<SubclassA>(22),
|
|
|
|
d = std::make_unique<SubclassB>();
|
2017-12-06 17:27:44 +00:00
|
|
|
|
|
|
|
// These 4 objects all have unique identities.
|
|
|
|
REPORTER_ASSERT(r, a != b);
|
|
|
|
REPORTER_ASSERT(r, a != c);
|
|
|
|
REPORTER_ASSERT(r, a != d);
|
|
|
|
REPORTER_ASSERT(r, b != c);
|
|
|
|
REPORTER_ASSERT(r, b != d);
|
|
|
|
REPORTER_ASSERT(r, c != d);
|
|
|
|
|
|
|
|
// Only b and d have the same val().
|
|
|
|
REPORTER_ASSERT(r, a->val() != b->val());
|
|
|
|
REPORTER_ASSERT(r, a->val() != c->val());
|
|
|
|
REPORTER_ASSERT(r, a->val() != d->val());
|
|
|
|
REPORTER_ASSERT(r, b->val() != c->val());
|
|
|
|
REPORTER_ASSERT(r, b->val() == d->val());
|
|
|
|
REPORTER_ASSERT(r, c->val() != d->val());
|
|
|
|
|
|
|
|
// SkVptr() returns the same value for objects of the same concrete type.
|
|
|
|
REPORTER_ASSERT(r, SkVptr(*a) == SkVptr(*c));
|
|
|
|
REPORTER_ASSERT(r, SkVptr(*b) == SkVptr(*d));
|
|
|
|
REPORTER_ASSERT(r, SkVptr(*a) != SkVptr(*b));
|
|
|
|
}
|