/* Copyright (C) 2003 MySQL AB This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; version 2 of the License. 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. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #ifndef DictCache_H #define DictCache_H #include #include #include #include #include #include #include #include #include #include "NdbLinHash.hpp" class Ndb_local_table_info { public: static Ndb_local_table_info *create(NdbTableImpl *table_impl, Uint32 sz=0); static void destroy(Ndb_local_table_info *); NdbTableImpl *m_table_impl; // range of cached tuple ids per thread Uint64 m_first_tuple_id; Uint64 m_last_tuple_id; Uint64 m_local_data[1]; // Must be last member. Used to access extra space. private: Ndb_local_table_info(NdbTableImpl *table_impl); ~Ndb_local_table_info(); }; /** * A non thread safe dict cache */ class LocalDictCache { public: LocalDictCache(); ~LocalDictCache(); Ndb_local_table_info * get(const char * name); void put(const char * name, Ndb_local_table_info *); void drop(const char * name); NdbLinHash m_tableHash; // On name }; /** * A thread safe dict cache */ class GlobalDictCache : public NdbLockable { public: GlobalDictCache(); ~GlobalDictCache(); NdbTableImpl * get(const char * name); NdbTableImpl* put(const char * name, NdbTableImpl *); void drop(NdbTableImpl *); void release(NdbTableImpl *); void alter_table_rep(const char * name, Uint32 tableId, Uint32 tableVersion, bool altered); unsigned get_size(); void invalidate_all(); public: enum Status { OK = 0, DROPPED = 1, RETREIVING = 2 }; private: void printCache(); struct TableVersion { Uint32 m_version; Uint32 m_refCount; NdbTableImpl * m_impl; Status m_status; }; NdbLinHash > m_tableHash; NdbCondition * m_waitForTableCondition; }; #endif