]> git.decadent.org.uk Git - dak.git/blob - tools/dsync-0.0/libdsync/contrib/mmap.h
utils.py
[dak.git] / tools / dsync-0.0 / libdsync / contrib / mmap.h
1 // -*- mode: cpp; mode: fold -*-
2 // Description                                                          /*{{{*/
3 // $Id: mmap.h,v 1.2 1999/10/24 06:53:12 jgg Exp $
4 /* ######################################################################
5    
6    MMap Class - Provides 'real' mmap or a faked mmap using read().
7
8    The purpose of this code is to provide a generic way for clients to
9    access the mmap function. In enviroments that do not support mmap
10    from file fd's this function will use read and normal allocated 
11    memory.
12    
13    Writing to a public mmap will always fully comit all changes when the 
14    class is deleted. Ie it will rewrite the file, unless it is readonly
15
16    The DynamicMMap class is used to help the on-disk data structure 
17    generators. It provides a large allocated workspace and members
18    to allocate space from the workspace in an effecient fashion.
19    
20    This source is placed in the Public Domain, do with it what you will
21    It was originally written by Jason Gunthorpe.
22    
23    ##################################################################### */
24                                                                         /*}}}*/
25 #ifndef PKGLIB_MMAP_H
26 #define PKGLIB_MMAP_H
27
28 #ifdef __GNUG__
29 #pragma interface "dsync/mmap.h"
30 #endif
31
32 #include <string>
33 #include <dsync/fileutl.h>
34
35 /* This should be a 32 bit type, larger tyes use too much ram and smaller
36    types are too small. Where ever possible 'unsigned long' should be used
37    instead of this internal type */
38 typedef unsigned int map_ptrloc;
39
40 class MMap
41 {
42    protected:
43    
44    unsigned long Flags;
45    unsigned long iSize;
46    void *Base;
47
48    bool Map(FileFd &Fd);
49    bool Close(bool DoSync = true);
50    
51    public:
52
53    enum OpenFlags {NoImmMap = (1<<0),Public = (1<<1),ReadOnly = (1<<2),
54                    UnMapped = (1<<3)};
55       
56    // Simple accessors
57    inline operator void *() {return Base;};
58    inline void *Data() {return Base;}; 
59    inline unsigned long Size() {return iSize;};
60    
61    // File manipulators
62    bool Sync();
63    bool Sync(unsigned long Start,unsigned long Stop);
64    
65    MMap(FileFd &F,unsigned long Flags);
66    MMap(unsigned long Flags);
67    virtual ~MMap();
68 };
69
70 class DynamicMMap : public MMap
71 {
72    public:
73    
74    // This is the allocation pool structure
75    struct Pool
76    {
77       unsigned long ItemSize;
78       unsigned long Start;
79       unsigned long Count;
80    };
81    
82    protected:
83    
84    FileFd *Fd;
85    unsigned long WorkSpace;
86    Pool *Pools;
87    unsigned int PoolCount;
88    
89    public:
90
91    // Allocation
92    unsigned long RawAllocate(unsigned long Size,unsigned long Aln = 0);
93    unsigned long Allocate(unsigned long ItemSize);
94    unsigned long WriteString(const char *String,unsigned long Len = (unsigned long)-1);
95    inline unsigned long WriteString(string S) {return WriteString(S.c_str());};
96    void UsePools(Pool &P,unsigned int Count) {Pools = &P; PoolCount = Count;};
97    
98    DynamicMMap(FileFd &F,unsigned long Flags,unsigned long WorkSpace = 2*1024*1024);
99    DynamicMMap(unsigned long Flags,unsigned long WorkSpace = 2*1024*1024);
100    virtual ~DynamicMMap();
101 };
102
103 #endif