Fix crash when generating instant preview of external inset.

git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@8803 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
Angus Leeming 2004-06-03 13:08:50 +00:00
parent 07dbb8fad8
commit 2ca14c025a
5 changed files with 50 additions and 11 deletions

View File

@ -1,3 +1,18 @@
2004-06-02 Angus Leeming <leeming@lyx.org>
Fix crash caused by dereferencing null pointer 'exportdata' in
OutputParams by creating a new ExportData variable on the heap,
storing it in a boost::shared_ptr.
The crash was triggered when generating an Instant Preview
of an external inset.
* Makefile.am: add outputparams.C
* outputparams.[Ch]: store exportdata as a shared_ptr<Exportdata>.
(c-tor): allocate memory to it.
* exporter.C (c-tor): associated changes.
2004-06-01 Angus Leeming <leeming@lyx.org> 2004-06-01 Angus Leeming <leeming@lyx.org>
* output_linuxdoc.C (linuxdocParagraphs): Check that the paragraph * output_linuxdoc.C (linuxdocParagraphs): Check that the paragraph

View File

@ -225,6 +225,7 @@ lyx_SOURCES = \
metricsinfo.h \ metricsinfo.h \
output.C \ output.C \
output.h \ output.h \
outputparams.C \
outputparams.h \ outputparams.h \
output_docbook.C \ output_docbook.C \
output_docbook.h \ output_docbook.h \

View File

@ -136,8 +136,6 @@ bool Exporter::Export(Buffer * buffer, string const & format,
OutputParams runparams; OutputParams runparams;
runparams.flavor = OutputParams::LATEX; runparams.flavor = OutputParams::LATEX;
runparams.linelen = lyxrc.ascii_linelen; runparams.linelen = lyxrc.ascii_linelen;
ExportData exportdata;
runparams.exportdata = &exportdata;
vector<string> backends = Backends(*buffer); vector<string> backends = Backends(*buffer);
if (find(backends.begin(), backends.end(), format) == backends.end()) { if (find(backends.begin(), backends.end(), format) == backends.end()) {
for (vector<string>::const_iterator it = backends.begin(); for (vector<string>::const_iterator it = backends.begin();
@ -200,7 +198,8 @@ bool Exporter::Export(Buffer * buffer, string const & format,
formats.extension(format)); formats.extension(format));
// We need to copy referenced files (e. g. included graphics // We need to copy referenced files (e. g. included graphics
// if format == "dvi") to the result dir. // if format == "dvi") to the result dir.
vector<ExportedFile> const files = exportdata.externalFiles(format); vector<ExportedFile> const files =
runparams.exportdata->externalFiles(format);
string const dest = OnlyPath(result_file); string const dest = OnlyPath(result_file);
CopyStatus status = SUCCESS; CopyStatus status = SUCCESS;
for (vector<ExportedFile>::const_iterator it = files.begin(); for (vector<ExportedFile>::const_iterator it = files.begin();

26
src/outputparams.C Normal file
View File

@ -0,0 +1,26 @@
/**
* \file outputparams.C
* This file is part of LyX, the document processor.
* Licence details can be found in the file COPYING.
*
* \author Angus Leeming
*
* Full author contact details are available in file CREDITS.
*/
#include <config.h>
#include "outputparams.h"
#include "exporter.h"
OutputParams::OutputParams()
: flavor(LATEX), nice(false), moving_arg(false),
free_spacing(false), use_babel(false),
mixed_content(false), linelen(0),
exportdata(new ExportData)
{}
OutputParams::~OutputParams()
{}

View File

@ -13,6 +13,7 @@
#define OUTPUTPARAMS_H #define OUTPUTPARAMS_H
#include "support/types.h" #include "support/types.h"
#include <boost/shared_ptr.hpp>
class ExportData; class ExportData;
@ -26,11 +27,8 @@ struct OutputParams {
XML XML
}; };
OutputParams() OutputParams();
: flavor(LATEX), nice(false), moving_arg(false), ~OutputParams();
free_spacing(false), use_babel(false),
mixed_content(false), linelen(0), exportdata(0)
{}
/** The latex that we export depends occasionally on what is to /** The latex that we export depends occasionally on what is to
compile the file. compile the file.
@ -60,7 +58,7 @@ struct OutputParams {
bool use_babel; bool use_babel;
/** Used for docbook to see if inside a region of mixed content. /** Used for docbook to see if inside a region of mixed content.
In that case all the white spaces are significant and can not appear In that case all the white spaces are significant and cannot appear
at the begin or end. at the begin or end.
*/ */
bool mixed_content; bool mixed_content;
@ -73,7 +71,7 @@ struct OutputParams {
This is a hack: Make it possible to add stuff to constant This is a hack: Make it possible to add stuff to constant
OutputParams instances. OutputParams instances.
*/ */
ExportData *exportdata; boost::shared_ptr<ExportData> exportdata;
}; };
#endif // LATEXRUNPARAMS_H #endif // NOT OUTPUTPARAMS_H