]> git.lyx.org Git - lyx.git/blobdiff - src/graphics/GraphicsCache.h
fix typo that put too many include paths for most people
[lyx.git] / src / graphics / GraphicsCache.h
index ebb0f7bcaf3dbae8b4d911af3e56eb68f5597368..dadec6c150d8ee54815dedf3ffab5d249e8e5a03 100644 (file)
@@ -1,13 +1,18 @@
 // -*- C++ -*-
-/* This file is part of
- * =================================================
- * 
- *          LyX, The Document Processor
- *          Copyright 1995 Matthias Ettrich.
- *          Copyright 1995-2000 The LyX Team.
+/**
+ *  \file GraphicsCache.h
+ *  Copyright 2002 the LyX Team
+ *  Read the file COPYING
  *
- *          This file Copyright 2000 Baruch Even
- * ================================================= */
+ * \author Baruch Even <baruch.even@writeme.com>
+ * \author Angus Leeming <a.leeming@ic.ac.uk>
+ *
+ *  grfx::GCache is the manager of the image cache.
+ *  It is responsible for creating the grfx::GCacheItem's and maintaining them.
+ *
+ *  grfx::GCache is a singleton class. It is possible to have only one
+ *  instance of it at any moment.
+ */
 
 #ifndef GRAPHICSCACHE_H
 #define GRAPHICSCACHE_H
 #pragma interface
 #endif
 
+#include "GraphicsTypes.h"
 #include <map>
-
 #include "LString.h"
-#include "GraphicsCacheItem.h"
-#include "support/utility.hpp"
-
-/** GraphicsCache is the manager of the image cache, it is responsible to
-    create the GraphicsCacheItem's and maintain them.
-    
-    GraphicsCache is a singleton class, there should be only one instance of
-    it at any moment.
-*/
-class GraphicsCache : public noncopyable {
+#include <boost/utility.hpp>
+
+class InsetGraphics;
+
+namespace grfx {
+
+class GCacheItem;
+
+class GCache : boost::noncopyable {
 public:
-    /// Get the instance of the class.
-    static GraphicsCache * getInstance();
 
-    /// Add a file to the cache.
-    GraphicsCacheItem * addFile(string const & filename);
+       /// This is a singleton class. Get the instance.
+       static GCache & get();
+
+       ///
+       ~GCache();
+
+       /// Add a file to the cache (or modify an existing image).
+       void update(InsetGraphics const &, string const & filepath);
+
+       /** Remove the data associated with this inset.
+        *  Called from the InsetGraphics d-tor.
+        */
+       void remove(InsetGraphics const &);
+
+       /** No processing of the image will take place until this call is
+        *  received.
+        */
+       void startLoading(InsetGraphics const &);
+
+       /** If (changed_background == true), then the background color of the
+        *  graphics inset has changed. Update all images.
+        *  Else, the preferred display type has changed.
+        *  Update the view of all insets whose display type is DEFAULT.
+        */
+       void changeDisplay(bool changed_background = false);
+
+       /// Get the image referenced by a particular inset.
+       ImagePtr const image(InsetGraphics const &) const;
+
+       /// How far have we got in loading the image?
+       ImageStatus status(InsetGraphics const &) const;
 
 private:
-    /// Remove a cache item if it's count has gone to zero.
-    void removeFile(string const & filename);
-    
-    /// Private c-tor so we can control how many objects are instantiated.
-    GraphicsCache() {}
-
-    /// Private d-tor so that no-one will destroy us.
-    ~GraphicsCache();
-
-    /// Holder of the single instance of the class.
-    static GraphicsCache * singleton;
-    ///
-    typedef std::map<string, GraphicsCacheItem *> CacheType;
-    ///
-    CacheType cache;
-
-       // We need this so that an Item can tell the cache that it should be
-       // deleted. (to call removeFile).
-       // It also helps removing a warning gcc emits.
-       friend class GraphicsCacheItem;
+       /** Make the c-tor private so we can control how many objects
+        *  are instantiated.
+        */
+       GCache();
+
+       /// The cache contains data of this type.
+       typedef boost::shared_ptr<GCacheItem> CacheItemType;
+
+       /** The cache contains one item per file, so use a map to find the
+        *  cache item quickly by filename.
+        *  Note that each cache item can have multiple views, potentially one
+        *  per inset that references the original file.
+        */
+       typedef std::map<string, CacheItemType> CacheType;
+
+       /// Search the cache by inset.
+       CacheType::const_iterator find(InsetGraphics const &) const;
+       ///
+       CacheType::iterator find(InsetGraphics const &);
+
+       /** Store a pointer to the cache so that we can forward declare
+        *  GCacheItem.
+        */
+       CacheType * cache;
 };
-#endif
+
+} // namespace grfx
+
+
+#endif // GRAPHICSCACHE_H