1 /* cache.h - definitions for the LRU cache
3 * Copyright (C) 2004-2006 Gerhard Häring <gh@ghaering.de>
5 * This file is part of pysqlite.
7 * This software is provided 'as-is', without any express or implied
8 * warranty. In no event will the authors be held liable for any damages
9 * arising from the use of this software.
11 * Permission is granted to anyone to use this software for any purpose,
12 * including commercial applications, and to alter it and redistribute it
13 * freely, subject to the following restrictions:
15 * 1. The origin of this software must not be misrepresented; you must not
16 * claim that you wrote the original software. If you use this software
17 * in a product, an acknowledgment in the product documentation would be
18 * appreciated but is not required.
19 * 2. Altered source versions must be plainly marked as such, and must not be
20 * misrepresented as being the original software.
21 * 3. This notice may not be removed or altered from any source distribution.
24 #ifndef PYSQLITE_CACHE_H
25 #define PYSQLITE_CACHE_H
28 /* The LRU cache is implemented as a combination of a doubly-linked with a
29 * dictionary. The list items are of type 'Node' and the dictionary has the
47 /* a dictionary mapping keys to Node entries */
50 /* the factory callable */
56 /* if set, decrement the factory function when the Cache is deallocated.
57 * this is almost always desirable, but not in the pysqlite context */
61 extern PyTypeObject NodeType
;
62 extern PyTypeObject CacheType
;
64 int node_init(Node
* self
, PyObject
* args
, PyObject
* kwargs
);
65 void node_dealloc(Node
* self
);
67 int cache_init(Cache
* self
, PyObject
* args
, PyObject
* kwargs
);
68 void cache_dealloc(Cache
* self
);
69 PyObject
* cache_get(Cache
* self
, PyObject
* args
);
71 int cache_setup_types(void);