/* * Copyright (c) 2019 TAOS Data, Inc. * * 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 . */ #include "tdbInt.h" struct STDB { STEnv *pEnv; SBTree *pBt; }; struct STDBC { SBTC btc; }; int tdbDbOpen(const char *fname, int keyLen, int valLen, FKeyComparator keyCmprFn, STEnv *pEnv, STDB **ppDb) { STDB *pDb; SPager *pPager; int ret; char fFullName[TDB_FILENAME_LEN]; SPage *pPage; SPgno pgno; *ppDb = NULL; pDb = (STDB *)tdbOsCalloc(1, sizeof(*pDb)); if (pDb == NULL) { return -1; } // pDb->pEnv pDb->pEnv = pEnv; pPager = tdbEnvGetPager(pEnv, fname); if (pPager == NULL) { snprintf(fFullName, TDB_FILENAME_LEN, "%s/%s", pEnv->rootDir, fname); ret = tdbPagerOpen(pEnv->pCache, fFullName, &pPager); if (ret < 0) { return -1; } } ASSERT(pPager != NULL); // pDb->pBt ret = tdbBtreeOpen(keyLen, valLen, pPager, keyCmprFn, &(pDb->pBt)); if (ret < 0) { return -1; } *ppDb = pDb; return 0; } int tdbDbClose(STDB *pDb) { // TODO return 0; } int tdbDbDrop(STDB *pDb) { // TODO return 0; } int tdbDbInsert(STDB *pDb, const void *pKey, int keyLen, const void *pVal, int valLen) { SBTC btc; SBTC *pCur; int ret; pCur = &btc; ret = tdbBtcOpen(pCur, pDb->pBt); if (ret < 0) { return -1; } ret = tdbBtCursorInsert(pCur, pKey, keyLen, pVal, valLen); if (ret < 0) { return -1; } return 0; } int tdbDbGet(STDB *pDb, const void *pKey, int kLen, void **ppVal, int *vLen) { return tdbBtreeGet(pDb->pBt, pKey, kLen, ppVal, vLen); } int tdbDbcOpen(STDB *pDb, STDBC **ppDbc) { int ret; STDBC *pDbc = NULL; *ppDbc = NULL; pDbc = (STDBC *)tdbOsMalloc(sizeof(*pDbc)); if (pDbc == NULL) { return -1; } tdbBtcOpen(&pDbc->btc, pDb->pBt); // TODO: move to first now, we can move to any key-value // and in any direction, design new APIs. ret = tdbBtcMoveToFirst(&pDbc->btc); if (ret < 0) { ASSERT(0); return -1; } *ppDbc = pDbc; return 0; } int tdbDbNext(STDBC *pDbc, void **ppKey, int *kLen, void **ppVal, int *vLen) { return tdbBtreeNext(&pDbc->btc, ppKey, kLen, ppVal, vLen); } int tdbDbcClose(STDBC *pDbc) { if (pDbc) { tdbOsFree(pDbc); } return 0; }