Skip to content
Snippets Groups Projects
Select Git revision
  • af43cd033c64384c521a9cb1fb68660d7799435c
  • master default protected
  • android-7.1.2_r28_klist
  • oreo-mr1-iot-release
  • sdk-release
  • pie-cts-dev
  • pie-cts-release
  • pie-vts-release
  • nougat-iot-release
  • pie-gsi
  • pie-platform-release
  • pie-r2-release
  • pie-r2-s1-release
  • pie-release
  • pie-dev
  • oreo-m4-s4-release
  • o-mr1-iot-preview-8
  • oreo-m2-s2-release
  • oreo-m2-s1-release
  • oreo-m6-s2-release
  • oreo-m6-s3-release
  • android-o-mr1-iot-release-1.0.4
  • android-9.0.0_r8
  • android-9.0.0_r7
  • android-9.0.0_r6
  • android-9.0.0_r5
  • android-8.1.0_r46
  • android-8.1.0_r45
  • android-n-iot-release-smart-display-r2
  • android-vts-8.1_r5
  • android-cts-8.1_r8
  • android-cts-8.0_r12
  • android-cts-7.1_r20
  • android-cts-7.0_r24
  • android-cts-6.0_r31
  • android-o-mr1-iot-release-1.0.3
  • android-cts-9.0_r1
  • android-8.1.0_r43
  • android-8.1.0_r42
  • android-n-iot-release-smart-display
  • android-p-preview-5
41 results

dynarray.c

Blame
  • dynarray.c 1.99 KiB
    #include "dynarray.h"
    #include <stdlib.h>
    #include <limits.h>
    
    void
    dynarray_init( dynarray_t *a )
    {
        a->count = a->capacity = 0;
        a->items = NULL;
    }
    
    
    static void
    dynarray_reserve_more( dynarray_t *a, int count )
    {
        int old_cap = a->capacity;
        int new_cap = old_cap;
        const int max_cap = INT_MAX/sizeof(void*);
        void** new_items;
        int new_count = a->count + count;
    
        if (count <= 0)
            return;
    
        if (count > max_cap - a->count)
            abort();
    
        new_count = a->count + count;
    
        while (new_cap < new_count) {
            old_cap = new_cap;
            new_cap += (new_cap >> 2) + 4;
            if (new_cap < old_cap || new_cap > max_cap) {
                new_cap = max_cap;
            }
        }
        new_items = realloc(a->items, new_cap*sizeof(void*));
        if (new_items == NULL)
            abort();
    
        a->items = new_items;
        a->capacity = new_cap;
    }
    
    void
    dynarray_append( dynarray_t *a, void* item )
    {
        if (a->count >= a->capacity)
            dynarray_reserve_more(a, 1);
    
        a->items[a->count++] = item;
    }
    
    void
    dynarray_done( dynarray_t *a )
    {
        free(a->items);
        a->items = NULL;
        a->count = a->capacity = 0;
    }
    
    // string arrays
    
    void strlist_init( strlist_t *list )
    {
        dynarray_init(list);
    }
    
    void strlist_append_b( strlist_t *list, const void* str, size_t  slen )
    {