/* Copyright (c) 2013 Microsoft Corporation. All rights reserved. Released under Apache 2.0 license as described in the file LICENSE. Author: Leonardo de Moura */ #include #include "util/test.h" #include "util/buffer.h" using namespace lean; template static void loop(int n) { C b; b.push_back(n); lean_assert(b.size() == 1); lean_assert(b.back() == n); lean_assert(b[0] == n); if (n > 0) loop(n-1); } static void tst1() { buffer b1; buffer b2; b1.push_back(10); lean_assert(b1 != b2); b2.push_back(20); lean_assert(b1 != b2); b2.pop_back(); b2.push_back(10); lean_assert(b1 == b2); b2.push_back(20); b2.push_back(20); lean_assert(b1 != b2); b2.shrink(1); lean_assert(b1 == b2); b2.push_back(100); lean_assert(b1 != b2); b2 = b1; lean_assert(b1 == b2); buffer b3(b1); lean_assert(b3 == b1); lean_assert(b1.back() == 10); } static void tst2() { buffer b1; buffer b2; b1.push_back(1); b1.push_back(2); b1.push_back(3); b2 = b1; lean_assert(b1.size() == 3); b2.resize(2); lean_assert(b2.size() == 2); b2.resize(10, 0); lean_assert(b2.size() == 10); b2.resize(1); lean_assert(b2.size() == 1); } int main() { loop>(100); tst1(); tst2(); return has_violations() ? 1 : 0; }