tdbUtil.c 1.9 KB
Newer Older
H
Hongze Cheng 已提交
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/>.
 */

H
Hongze Cheng 已提交
16
#include "tdbInt.h"
H
Hongze Cheng 已提交
17

H
Hongze Cheng 已提交
18
int tdbGnrtFileID(const char *fname, uint8_t *fileid, bool unique) {
H
Hongze Cheng 已提交
19 20 21 22 23 24 25 26 27 28
  struct stat statbuf;

  if (stat(fname, &statbuf) < 0) {
    return -1;
  }

  memset(fileid, 0, TDB_FILE_ID_LEN);

  ((uint64_t *)fileid)[0] = (uint64_t)statbuf.st_ino;
  ((uint64_t *)fileid)[1] = (uint64_t)statbuf.st_dev;
H
Hongze Cheng 已提交
29 30 31
  if (unique) {
    ((uint64_t *)fileid)[2] = rand();
  }
H
Hongze Cheng 已提交
32 33 34 35

  return 0;
}

H
Hongze Cheng 已提交
36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51
int tdbCheckFileAccess(const char *pathname, int mode) {
  int flags = 0;

  if (mode & TDB_F_OK) {
    flags |= F_OK;
  }

  if (mode & TDB_R_OK) {
    flags |= R_OK;
  }

  if (mode & TDB_W_OK) {
    flags |= W_OK;
  }

  return access(pathname, flags);
H
Hongze Cheng 已提交
52 53
}

H
more  
Hongze Cheng 已提交
54
int tdbGetFileSize(const char *fname, int pgSize, SPgno *pSize) {
H
Hongze Cheng 已提交
55 56 57 58 59 60 61 62 63 64 65
  struct stat st;
  int         ret;

  ret = stat(fname, &st);
  if (ret != 0) {
    return -1;
  }

  ASSERT(st.st_size % pgSize == 0);

  *pSize = st.st_size / pgSize;
H
Hongze Cheng 已提交
66
  return 0;
H
Hongze Cheng 已提交
67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91
}

int tdbPRead(int fd, void *pData, int count, i64 offset) {
  void *pBuf;
  int   nbytes;
  i64   ioffset;
  int   iread;

  pBuf = pData;
  nbytes = count;
  ioffset = offset;
  while (nbytes > 0) {
    iread = pread(fd, pBuf, nbytes, ioffset);
    if (iread < 0) {
      /* TODO */
    } else if (iread == 0) {
      return (count - iread);
    }

    nbytes = nbytes - iread;
    pBuf = (void *)((u8 *)pBuf + iread);
    ioffset += iread;
  }

  return count;
H
Hongze Cheng 已提交
92
}