X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Finsets%2FInsetInclude.h;h=0e14405a8a6305abb774125c33f1cb757fe65c8e;hb=67e70c6c022fa445cd654937faeb87955e3bca7a;hp=cdb819f612b0c80bd5c937fad20e9319f97dd5b2;hpb=c81fd7337d725cbc6b1db6d88e827d3b4f87f995;p=lyx.git diff --git a/src/insets/InsetInclude.h b/src/insets/InsetInclude.h index cdb819f612..0e14405a8a 100644 --- a/src/insets/InsetInclude.h +++ b/src/insets/InsetInclude.h @@ -4,7 +4,7 @@ * This file is part of LyX, the document processor. * Licence details can be found in the file COPYING. * - * \author Lars Gullik Bjønnes + * \author Lars Gullik Bjønnes * \author Richard Heck (conversion to InsetCommand) * * Full author contact details are available in file CREDITS. @@ -13,13 +13,14 @@ #ifndef INSET_INCLUDE_H #define INSET_INCLUDE_H -#include "BiblioInfo.h" #include "InsetCommand.h" + +#include "BiblioInfo.h" +#include "Counters.h" #include "InsetCommandParams.h" #include "RenderButton.h" -#include "MailInset.h" -#include "Counters.h" -#include "EmbeddedFiles.h" + +#include "support/FileNameList.h" #include @@ -27,40 +28,34 @@ namespace lyx { class Buffer; class Dimension; +class InsetLabel; class LaTeXFeatures; class RenderMonitoredPreview; -namespace support { -class FileNameList; -} - /// for including tex/lyx files class InsetInclude : public InsetCommand { public: /// InsetInclude(InsetCommandParams const &); + ~InsetInclude(); + + void setBuffer(Buffer & buffer); + bool isLabeled() const { return true; } /// Override these InsetButton methods if Previewing void metrics(MetricsInfo & mi, Dimension & dim) const; /// void draw(PainterInfo & pi, int x, int y) const; /// - virtual DisplayType display() const; + DisplayType display() const; /// InsetCode lyxCode() const { return INCLUDE_CODE; } - /** Fills \c list - * \param buffer the Buffer containing this inset. - * \param list the list of labels in the child buffer. - */ - void getLabelList(Buffer const & buffer, - std::vector & list) const; /** Fills \c keys * \param buffer the Buffer containing this inset. * \param keys the list of bibkeys in the child buffer. * \param it not used here */ - virtual void fillWithBibKeys(Buffer const & buffer, - BiblioInfo & keys, InsetIterator const & it) const; + void fillWithBibKeys(BiblioInfo & keys, InsetIterator const & it) const; /** Update the cache with all bibfiles in use of the child buffer * (including bibfiles of grandchild documents). @@ -68,81 +63,81 @@ public: * automatic loading of all child documents upon loading the master. * \param buffer the Buffer containing this inset. */ - void updateBibfilesCache(Buffer const & buffer); + void updateBibfilesCache(); /** Return the cache with all bibfiles in use of the child buffer * (including bibfiles of grandchild documents). * Return an empty vector if the child doc is not loaded. * \param buffer the Buffer containing this inset. */ support::FileNameList const & - getBibfilesCache(Buffer const & buffer) const; + getBibfilesCache() const; /// - EDITABLE editable() const { return IS_EDITABLE; } + bool hasSettings() const { return true; } /// - int latex(Buffer const &, odocstream &, - OutputParams const &) const; + int latex(odocstream &, OutputParams const &) const; /// - int plaintext(Buffer const &, odocstream &, - OutputParams const &) const; + int plaintext(odocstream &, OutputParams const &) const; /// - int docbook(Buffer const &, odocstream &, - OutputParams const &) const; + int docbook(odocstream &, OutputParams const &) const; /// void validate(LaTeXFeatures &) const; /// void addPreview(graphics::PreviewLoader &) const; /// - void addToToc(TocList &, Buffer const &, ParConstIterator const &) const; + void addToToc(DocIterator const &); /// - void updateLabels(Buffer const & buffer, ParIterator const &); - /// child document can be embedded - void registerEmbeddedFiles(Buffer const &, EmbeddedFiles &) const; + void updateCommand(); /// - void updateEmbeddedFile(Buffer const & buf, EmbeddedFile const & file); + void updateLabels(ParIterator const &); /// - static CommandInfo const * findInfo(std::string const &); + static ParamInfo const & findInfo(std::string const &); /// - static std::string defaultCommand() { return "include"; }; + static std::string defaultCommand() { return "include"; } /// static bool isCompatibleCommand(std::string const & s); + /// + docstring contextMenu(BufferView const & bv, int x, int y) const; + /// \return the child buffer if the file is a LyX doc and could be loaded + Buffer * getChildBuffer() const; protected: InsetInclude(InsetInclude const &); /// - virtual void doDispatch(Cursor & cur, FuncRequest & cmd); + void doDispatch(Cursor & cur, FuncRequest & cmd); + /// + bool getStatus(Cursor & cur, FuncRequest const & cmd, FuncStatus &) const; private: - virtual Inset * clone() const; + Inset * clone() const { return new InsetInclude(*this); } /** Slot receiving a signal that the external file has changed * and the preview should be regenerated. */ void fileChanged() const; + /// \return loaded Buffer or zero if the file loading did not proceed. + Buffer * loadIfNeeded() const; + /// launch external application + void editIncluded(std::string const & file); /// set the parameters - void set(InsetCommandParams const & params, Buffer const &); + void setParams(InsetCommandParams const & params); /// get the text displayed on the button - docstring const getScreenLabel(Buffer const &) const; + docstring screenLabel() const; /// holds the entity name that defines the file location (SGML) docstring const include_label; /// The pointer never changes although *preview_'s contents may. boost::scoped_ptr const preview_; + /// + mutable bool failedtoload_; /// cache mutable bool set_label_; mutable RenderButton button_; mutable docstring listings_label_; + InsetLabel * label_; + mutable Buffer * child_buffer_; }; -/// return the child buffer if the file is a LyX doc and is loaded -Buffer * getChildBuffer(Buffer const & buffer, InsetCommandParams const & params); - -/// return loaded Buffer or zero if the file loading did not proceed. -Buffer * loadIfNeeded(Buffer const & parent, InsetCommandParams const & params); - -/// -void resetParentBuffer(Buffer const * parent, InsetCommandParams const & params, - bool close_it); } // namespace lyx -#endif // INSETINCLUDE_H +#endif // INSET_INCLUDE_H