symbian-qemu-0.9.1-12/python-2.6.1/Modules/_sqlite/cache.h
changeset 1 2fb8b9db1c86
equal deleted inserted replaced
0:ffa851df0825 1:2fb8b9db1c86
       
     1 /* cache.h - definitions for the LRU cache
       
     2  *
       
     3  * Copyright (C) 2004-2007 Gerhard Häring <gh@ghaering.de>
       
     4  *
       
     5  * This file is part of pysqlite.
       
     6  *
       
     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.
       
    10  *
       
    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:
       
    14  *
       
    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.
       
    22  */
       
    23 
       
    24 #ifndef PYSQLITE_CACHE_H
       
    25 #define PYSQLITE_CACHE_H
       
    26 #include "Python.h"
       
    27 
       
    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
       
    30  * nodes as values. */
       
    31 
       
    32 typedef struct _pysqlite_Node
       
    33 {
       
    34     PyObject_HEAD
       
    35     PyObject* key;
       
    36     PyObject* data;
       
    37     long count;
       
    38     struct _pysqlite_Node* prev;
       
    39     struct _pysqlite_Node* next;
       
    40 } pysqlite_Node;
       
    41 
       
    42 typedef struct
       
    43 {
       
    44     PyObject_HEAD
       
    45     int size;
       
    46 
       
    47     /* a dictionary mapping keys to Node entries */
       
    48     PyObject* mapping;
       
    49 
       
    50     /* the factory callable */
       
    51     PyObject* factory;
       
    52 
       
    53     pysqlite_Node* first;
       
    54     pysqlite_Node* last;
       
    55 
       
    56     /* if set, decrement the factory function when the Cache is deallocated.
       
    57      * this is almost always desirable, but not in the pysqlite context */
       
    58     int decref_factory;
       
    59 } pysqlite_Cache;
       
    60 
       
    61 extern PyTypeObject pysqlite_NodeType;
       
    62 extern PyTypeObject pysqlite_CacheType;
       
    63 
       
    64 int pysqlite_node_init(pysqlite_Node* self, PyObject* args, PyObject* kwargs);
       
    65 void pysqlite_node_dealloc(pysqlite_Node* self);
       
    66 
       
    67 int pysqlite_cache_init(pysqlite_Cache* self, PyObject* args, PyObject* kwargs);
       
    68 void pysqlite_cache_dealloc(pysqlite_Cache* self);
       
    69 PyObject* pysqlite_cache_get(pysqlite_Cache* self, PyObject* args);
       
    70 
       
    71 int pysqlite_cache_setup_types(void);
       
    72 
       
    73 #endif