1ffc67bb3SDavid Spickett //===-- flang/unittests/Runtime/Ragged.cpp ----------------------*- C++ -*-===//
2ffc67bb3SDavid Spickett //
3ffc67bb3SDavid Spickett // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4ffc67bb3SDavid Spickett // See https://llvm.org/LICENSE.txt for license information.
5ffc67bb3SDavid Spickett // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6ffc67bb3SDavid Spickett //
7ffc67bb3SDavid Spickett //===----------------------------------------------------------------------===//
8ffc67bb3SDavid Spickett
9ffc67bb3SDavid Spickett #include "flang/Runtime/ragged.h"
10ffc67bb3SDavid Spickett #include "gtest/gtest.h"
11ffc67bb3SDavid Spickett
12ffc67bb3SDavid Spickett using namespace Fortran::runtime;
13ffc67bb3SDavid Spickett
TEST(Ragged,RaggedArrayAllocateDeallocateTest)14ffc67bb3SDavid Spickett TEST(Ragged, RaggedArrayAllocateDeallocateTest) {
15ffc67bb3SDavid Spickett struct RaggedArrayHeader header;
16ffc67bb3SDavid Spickett unsigned rank = 2;
17*cd550463SKrzysztof Parzyszek int64_t *extents = reinterpret_cast<int64_t *>(malloc(2 * sizeof(int64_t)));
18ffc67bb3SDavid Spickett extents[0] = 10;
19ffc67bb3SDavid Spickett extents[1] = 100;
20ffc67bb3SDavid Spickett RaggedArrayHeader *ret = (RaggedArrayHeader *)_FortranARaggedArrayAllocate(
21ffc67bb3SDavid Spickett &header, false, rank, 32, extents);
22ffc67bb3SDavid Spickett EXPECT_TRUE(ret != nullptr);
23ffc67bb3SDavid Spickett EXPECT_TRUE(ret->bufferPointer != nullptr);
24ffc67bb3SDavid Spickett EXPECT_EQ(extents, ret->extentPointer);
25ffc67bb3SDavid Spickett EXPECT_EQ(10, ret->extentPointer[0]);
26ffc67bb3SDavid Spickett EXPECT_EQ(100, ret->extentPointer[1]);
27ffc67bb3SDavid Spickett EXPECT_EQ(rank, ret->flags >> 1);
28ffc67bb3SDavid Spickett EXPECT_FALSE(ret->flags & 1);
29ffc67bb3SDavid Spickett
30ffc67bb3SDavid Spickett _FortranARaggedArrayDeallocate(ret);
31ffc67bb3SDavid Spickett EXPECT_EQ(0u, ret->flags);
32ffc67bb3SDavid Spickett }
33