/*------------------------------------------------------------------------- * drawElements Memory Pool Library * -------------------------------- * * Copyright 2014 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * *//*! * \file * \brief Memory pool heap class. *//*--------------------------------------------------------------------*/ #include "dePoolHeap.h" #include "deInt32.h" #include <stdlib.h> #include <string.h> typedef struct HeapItem_s { int priority; int value; } HeapItem; DE_INLINE HeapItem HeapItem_create (int priority, int value) { HeapItem h; h.priority = priority; h.value = value; return h; } DE_INLINE int HeapItem_cmp (HeapItem a, HeapItem b) { if (a.priority < b.priority) return -1; if (a.priority > b.priority) return +1; return 0; } DE_DECLARE_POOL_HEAP(TestHeap, HeapItem, HeapItem_cmp); /*--------------------------------------------------------------------*//*! * \internal * \brief Test heap functionality. *//*--------------------------------------------------------------------*/ void dePoolHeap_selfTest (void) { deMemPool* pool = deMemPool_createRoot(DE_NULL, 0); TestHeap* heap = TestHeap_create(pool); int i; TestHeap_push(heap, HeapItem_create(10, 10)); TestHeap_push(heap, HeapItem_create(0, 10)); TestHeap_push(heap, HeapItem_create(20, 10)); DE_TEST_ASSERT(TestHeap_getNumElements(heap) == 3); DE_TEST_ASSERT(TestHeap_popMin(heap).priority == 0); DE_TEST_ASSERT(TestHeap_popMin(heap).priority == 10); DE_TEST_ASSERT(TestHeap_popMin(heap).priority == 20); DE_TEST_ASSERT(TestHeap_getNumElements(heap) == 0); /* Push items -1000..1000 into heap. */ for (i = -1000; i < 1000; i++) { /* Dummy alloc to try to break alignments. */ deMemPool_alloc(pool, 1); TestHeap_push(heap, HeapItem_create(i, -i)); } DE_TEST_ASSERT(TestHeap_getNumElements(heap) == 2000); /* Push items -2500..-3000 into heap. */ for (i = -2501; i >= -3000; i--) TestHeap_push(heap, HeapItem_create(i, -i)); DE_TEST_ASSERT(TestHeap_getNumElements(heap) == 2500); /* Push items 6000..7500 into heap. */ for (i = 6000; i < 7500; i++) TestHeap_push(heap, HeapItem_create(i, -i)); DE_TEST_ASSERT(TestHeap_getNumElements(heap) == 4000); /* Pop -3000..-2500 from heap. */ for (i = -3000; i < -2500; i++) { HeapItem h = TestHeap_popMin(heap); DE_TEST_ASSERT(h.priority == i); DE_TEST_ASSERT(h.value == -h.priority); } DE_TEST_ASSERT(TestHeap_getNumElements(heap) == 3500); /* Pop -1000..1000 from heap. */ for (i = -1000; i < 1000; i++) { HeapItem h = TestHeap_popMin(heap); DE_TEST_ASSERT(h.priority == i); DE_TEST_ASSERT(h.value == -h.priority); } DE_TEST_ASSERT(TestHeap_getNumElements(heap) == 1500); /* Pop 6000..7500 from heap. */ for (i = 6000; i < 7500; i++) { HeapItem h = TestHeap_popMin(heap); DE_TEST_ASSERT(h.priority == i); DE_TEST_ASSERT(h.value == -h.priority); } DE_TEST_ASSERT(TestHeap_getNumElements(heap) == 0); deMemPool_destroy(pool); }