fix redraw at top-left of map
[Tsunagari.git] / src / resourcer.h
blob7b71194572b2cdb2d96cc9822630ece1cd385e02
1 /******************************
2 ** Tsunagari Tile Engine **
3 ** resourcer.h **
4 ** Copyright 2011 OmegaSDG **
5 ******************************/
7 #ifndef RESOURCER_H
8 #define RESOURCER_H
10 #include <deque>
11 #include <string>
12 #include <utility>
14 #include <boost/scoped_ptr.hpp>
15 #include <boost/shared_ptr.hpp>
16 #include <boost/unordered_map.hpp>
17 #include <libxml/parser.h>
18 #include <libxml/tree.h>
20 #include "common.h"
22 struct zip;
24 namespace Gosu {
25 class Bitmap;
26 class Buffer;
27 class Image;
28 class Sample;
31 class GameWindow;
33 // We hand out and manage Gosu resources in these forms:
34 typedef boost::scoped_ptr<Gosu::Buffer> BufferPtr;
35 typedef boost::shared_ptr<Gosu::Image> ImageRef;
36 typedef boost::shared_ptr<Gosu::Sample> SampleRef;
37 typedef std::deque<ImageRef> TiledImage;
38 // libxml2 resources
39 typedef boost::shared_ptr<xmlDoc> XMLDocRef;
41 //! Resourcer Class
42 /*!
43 This class provides the engine's global resource handling and caching.
45 class Resourcer
47 public:
48 Resourcer(GameWindow* window, ClientValues* conf);
49 ~Resourcer();
50 bool init();
52 //! Expunge old stuff from the cache.
53 void garbageCollect();
55 //! Requests an image resource from cache.
56 ImageRef getImage(const std::string& name);
58 //! Requests an image resource from cache and splits it into a number
59 // of tiles each with width and height w by x. Returns false if the
60 // source image wasn't found.
61 bool getTiledImage(TiledImage& img, const std::string& name,
62 unsigned w, unsigned h, bool tileable);
64 //! Returns a music stream from disk or cache.
65 SampleRef getSample(const std::string& name);
67 //! Requests an XML resource from cache.
68 XMLDocRef getXMLDoc(const std::string& name,
69 const std::string& dtdFile);
71 private:
72 template<class Res>
73 struct CachedItem
75 Res resource;
76 int lastUsed;
77 int memoryUsed;
80 //! Resource maps.
81 typedef boost::unordered_map<std::string, CachedItem<ImageRef> >
82 ImageRefMap;
83 typedef boost::unordered_map<std::string, CachedItem<SampleRef> >
84 SampleRefMap;
85 typedef boost::unordered_map<std::string, CachedItem<XMLDocRef> >
86 XMLMap;
87 typedef boost::unordered_map<std::string, CachedItem<
88 boost::shared_ptr<TiledImage> > > TiledImageMap;
90 //! Garbage collect a map.
91 template<class Map, class MapValue>
92 void reclaim(Map& map);
94 //! Reads an XML document from disk and parses it.
95 xmlDoc* readXMLDocFromDisk(const std::string& name,
96 const std::string& dtdFile);
98 //! Read a string resource from disk.
99 std::string readStringFromDisk(const std::string& name);
101 //! Read a generic resource from disk.
102 Gosu::Buffer* read(const std::string& name);
104 //! Helper function
105 std::string path(const std::string& entryName) const;
107 GameWindow* window;
108 zip* z;
109 ClientValues* conf;
111 //! Resource Cache
113 The key is the cached file's name, and the value is a pair of a
114 "tally" and a pointer to the data. The "tally" is increased each
115 time something requests the resource, and decreased each time
116 something is finished with that resource. When the tally reaches
117 zero, nothing is using the resource, and it is dropped after a
118 few minutes. The cache drop timer is in a thread.
120 ImageRefMap images;
121 SampleRefMap samples;
122 XMLMap xmls;
123 TiledImageMap tiles;
126 #endif