1 /* This file is part of
2 * =================================================
4 * LyX, The Document Processor
5 * Copyright 1995 Matthias Ettrich.
6 * Copyright 1995-2001 The LyX Team.
8 * This file Copyright 2000 Baruch Even
9 * ================================================= */
14 #pragma implementation
17 #include "graphics/GraphicsCache.h"
18 #include "graphics/GraphicsCacheItem.h"
19 #include "frontends/support/LyXImage.h"
20 #include "graphics/ImageLoaderXPM.h"
21 #include "converter.h"
22 #include "support/filetools.h"
23 #include "support/lyxlib.h"
24 #include "lyx_gui_misc.h"
26 #include "support/LAssert.h"
32 * The order of conversion:
34 * The c-tor calls convertImage()
36 * convertImage() verifies that we need to do conversion, if not it will just
37 * call the loadImage()
38 * if conversion is needed, it will initiate the conversion.
40 * When the conversion is completed imageConverted() is called, which in turn
43 * Since we currently do everything synchronously, convertImage() calls
44 * imageConverted() right after it does the call to the conversion process.
47 GraphicsCacheItem::GraphicsCacheItem(string const & filename)
48 : imageStatus_(GraphicsCacheItem::Loading)
52 bool success = convertImage(filename);
53 if (! success) // Conversion failed miserably (couldn't even start).
54 setStatus(ErrorConverting);
58 GraphicsCacheItem::~GraphicsCacheItem()
62 GraphicsCacheItem::ImageStatus
63 GraphicsCacheItem::getImageStatus() const { return imageStatus_; }
66 void GraphicsCacheItem::setStatus(ImageStatus new_status)
68 imageStatus_ = new_status;
73 GraphicsCacheItem::getImage() const { return image_.get(); }
77 GraphicsCacheItem::imageConverted(bool success)
80 string text = "succeeded";
83 lyxerr << "imageConverted, conversion " << text << "." << endl;
86 lyxerr << "(GraphicsCacheItem::imageConverter) "
87 "Error converting image." << endl;
88 setStatus(GraphicsCacheItem::ErrorConverting);
92 // Do the actual image loading from file to memory.
99 string const findTargetFormat(string const & from)
101 typedef ImageLoader::FormatList FormatList;
102 FormatList formats = ImageLoaderXPM().loadableFormats();
103 lyx::Assert(formats.size() > 0); // There must be a format to load from.
105 FormatList::const_iterator iter = formats.begin();
106 FormatList::const_iterator end = formats.end();
108 for (; iter != end; ++iter) {
109 if (converters.isReachable(from, *iter))
114 // We do not know how to convert the image to something loadable.
115 lyxerr << "ERROR: Do not know how to convert image." << std::endl;
126 GraphicsCacheItem::convertImage(string const & filename)
128 string const from = GetExtension(filename);
129 string const to = findTargetFormat(from);
134 // No conversion needed!
135 // Saves more than just time: prevents the deletion of
136 // the "to" file after loading when it's the same as the "from"!
142 // Take only the filename part of the file, without path or extension.
143 string temp = OnlyFilename(filename);
144 temp = ChangeExtension(filename, string());
146 // Add some stuff to have it a unique temp file.
147 // This tempfile is deleted in loadImage after it is loaded to memory.
148 tempfile = lyx::tempName(string(), temp);
149 // Remove the temp file, we only want the name...
150 lyx::unlink(tempfile);
152 bool result = converters.convert(0, filename, tempfile, from, to);
153 tempfile.append(".xpm");
155 // For now we are synchronous
156 imageConverted(result);
158 // Cleanup after the conversion.
159 lyx::unlink(tempfile);
166 // This function gets called from the callback after the image has been
167 // converted successfully.
169 GraphicsCacheItem::loadImage()
171 lyxerr << "Loading XPM Image... ";
173 ImageLoaderXPM imageLoader;
174 if (imageLoader.loadImage(tempfile) == ImageLoader::OK) {
175 lyxerr << "Success." << endl;
176 image_.reset(imageLoader.getImage());
177 setStatus(GraphicsCacheItem::Loaded);
179 lyxerr << "Loading " << tempfile << "Failed" << endl;
180 setStatus(GraphicsCacheItem::ErrorReading);