indexFstSparse.c 2.2 KB
Newer Older
dengyihao's avatar
add UT  
dengyihao 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
/*
 * Copyright (c) 2019 TAOS Data, Inc. <jhtao@taosdata.com>
 *
 * This program is free software: you can use, redistribute, and/or modify
 * it under the terms of the GNU Affero General Public License, version 3
 * or later ("AGPL"), as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with this program. If not, see <http://www.gnu.org/licenses/>.
 */

dengyihao's avatar
dengyihao 已提交
16
#include "indexFstSparse.h"
dengyihao's avatar
dengyihao 已提交
17 18 19

FstSparseSet *sparSetCreate(int32_t sz) {
  FstSparseSet *ss = taosMemoryCalloc(1, sizeof(FstSparseSet));
wafwerar's avatar
wafwerar 已提交
20
  if (ss == NULL) {
dengyihao's avatar
dengyihao 已提交
21 22 23
    return NULL;
  }

dengyihao's avatar
dengyihao 已提交
24 25 26 27 28 29
  ss->dense = (int32_t *)taosMemoryMalloc(sz * sizeof(int32_t));
  memset(ss->dense, -1, sz * sizeof(int32_t));
  ss->sparse = (int32_t *)taosMemoryMalloc(sz * sizeof(int32_t));
  memset(ss->sparse, -1, sz * sizeof(int32_t));
  ss->cap = sz;

dengyihao's avatar
dengyihao 已提交
30
  ss->size = 0;
dengyihao's avatar
dengyihao 已提交
31 32 33 34 35 36
  return ss;
}
void sparSetDestroy(FstSparseSet *ss) {
  if (ss == NULL) {
    return;
  }
dengyihao's avatar
dengyihao 已提交
37 38
  taosMemoryFree(ss->dense);
  taosMemoryFree(ss->sparse);
dengyihao's avatar
dengyihao 已提交
39 40
  taosMemoryFree(ss);
}
dengyihao's avatar
dengyihao 已提交
41 42 43 44
uint32_t sparSetLen(FstSparseSet *ss) {
  // Get occupied size
  return ss == NULL ? 0 : ss->size;
}
dengyihao's avatar
dengyihao 已提交
45
bool sparSetAdd(FstSparseSet *ss, int32_t ip, int32_t *idx) {
dengyihao's avatar
dengyihao 已提交
46
  if (ss == NULL) {
dengyihao's avatar
dengyihao 已提交
47 48 49 50
    return false;
  }
  if (ip >= ss->cap) {
    return false;
dengyihao's avatar
dengyihao 已提交
51 52
  }
  uint32_t i = ss->size;
dengyihao's avatar
dengyihao 已提交
53 54
  ss->dense[i] = ip;
  ss->sparse[ip] = i;
dengyihao's avatar
dengyihao 已提交
55
  ss->size += 1;
dengyihao's avatar
dengyihao 已提交
56 57 58 59

  if (idx != NULL) *idx = i;

  return true;
dengyihao's avatar
dengyihao 已提交
60
}
dengyihao's avatar
dengyihao 已提交
61 62 63 64 65 66 67 68 69
bool sparSetGet(FstSparseSet *ss, int32_t idx, int32_t *ip) {
  if (idx >= ss->cap || idx >= ss->size) {
    return false;
  }
  int32_t val = ss->dense[idx];
  if (ip != NULL) {
    *ip = val;
  }
  return val == -1 ? false : true;
dengyihao's avatar
dengyihao 已提交
70
}
dengyihao's avatar
dengyihao 已提交
71 72 73 74 75 76 77
bool sparSetContains(FstSparseSet *ss, int32_t ip) {
  if (ip >= ss->cap) {
    return false;
  }
  int32_t i = ss->sparse[ip];

  if (i < ss->cap && i < ss->size && ss->dense[i] == ip) {
dengyihao's avatar
dengyihao 已提交
78 79
    return true;
  } else {
dengyihao's avatar
dengyihao 已提交
80 81 82 83 84 85 86
    return false;
  }
}
void sparSetClear(FstSparseSet *ss) {
  if (ss == NULL) {
    return;
  }
dengyihao's avatar
dengyihao 已提交
87 88
  memset(ss->dense, -1, ss->cap * sizeof(int32_t));
  memset(ss->sparse, -1, ss->cap * sizeof(int32_t));
dengyihao's avatar
dengyihao 已提交
89 90
  ss->size = 0;
}