ISLTools.cpp
851 Bytes
#include "polly/Support/ISLTools.h"
#include "gmock/gmock.h"
#include "gtest/gtest.h"
namespace isl {
static bool operator==(const isl::basic_set &A, const isl::basic_set &B) {
return A.is_equal(B);
}
} // namespace isl
TEST(Support, isl_iterator) {
std::unique_ptr<isl_ctx, decltype(&isl_ctx_free)> RawCtx(isl_ctx_alloc(),
&isl_ctx_free);
isl::ctx Ctx(RawCtx.get());
isl::basic_set A(
Ctx, "{ [x, y] : 0 <= x <= 5 and y >= 0 and x > 0 and 0 < y <= 5 }");
isl::basic_set B(
Ctx, "{ [x, y] : 0 <= x <= 5 and y >= 0 and x <= 4 and y <= 3 + x }");
isl::set S = A.unite(B);
ASSERT_EQ(S.n_basic_set(), 2);
std::vector<isl::basic_set> Sets;
for (auto BS : S.get_basic_set_list())
Sets.push_back(BS);
EXPECT_THAT(Sets, testing::UnorderedElementsAre(A, B));
}