X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Finsets%2FInsetInclude.h;h=b66a21b829ff578eec61ff8a02d1c7c4e557553b;hb=5eb7add4092708a5a0dbabf303164be624aff72f;hp=78cfa959a6ad61ae4ce574098622d6927106f325;hpb=f53467871fc0ac2132ae7e449cd3fbaaaa5501a6;p=lyx.git diff --git a/src/insets/InsetInclude.h b/src/insets/InsetInclude.h index 78cfa959a6..b66a21b829 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,34 +13,64 @@ #ifndef INSET_INCLUDE_H #define INSET_INCLUDE_H -#include "BiblioInfo.h" #include "InsetCommand.h" -#include "InsetCommandParams.h" + #include "RenderButton.h" -#include "MailInset.h" -#include "Counters.h" -#include "EmbeddedFiles.h" #include namespace lyx { +class BiblioInfo; class Buffer; class Dimension; +class InsetCommandParams; class InsetLabel; class LaTeXFeatures; class RenderMonitoredPreview; +namespace support { + class FileNameList; +} + /// for including tex/lyx files class InsetInclude : public InsetCommand { public: /// - InsetInclude(InsetCommandParams const &); + InsetInclude(Buffer * buf, InsetCommandParams const &); + /// ~InsetInclude(); + /// + void setChildBuffer(Buffer * buffer); + /// \return the child buffer if the file is a LyX doc and could be loaded + Buffer * getChildBuffer() const; + + /** Update the cache with all bibfiles in use of the child buffer + * (including bibfiles of grandchild documents). + * Does nothing if the child document is not loaded to prevent + * automatic loading of all child documents upon loading the master. + * \param buffer the Buffer containing this inset. + */ + 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() const; + + /// + void updateCommand(); + + /// \name Public functions inherited from Inset class + //@{ + /// void setBuffer(Buffer & buffer); + /// bool isLabeled() const { return true; } - /// Override these InsetButton methods if Previewing void metrics(MetricsInfo & mi, Dimension & dim) const; /// @@ -49,29 +79,13 @@ public: DisplayType display() const; /// InsetCode lyxCode() const { return INCLUDE_CODE; } - /** Fills \c keys - * \param buffer the Buffer containing this inset. + /** Fills \c key * \param keys the list of bibkeys in the child buffer. * \param it not used here */ 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). - * Does nothing if the child document is not loaded to prevent - * automatic loading of all child documents upon loading the master. - * \param buffer the Buffer containing this inset. - */ - 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. - */ - EmbeddedFileList const & - getBibfilesCache(Buffer const & buffer) const; /// - EDITABLE editable() const { return IS_EDITABLE; } + bool hasSettings() const { return true; } /// int latex(odocstream &, OutputParams const &) const; /// @@ -79,55 +93,80 @@ public: /// int docbook(odocstream &, OutputParams const &) const; /// + docstring xhtml(XHTMLStream &, OutputParams const &) const; + /// void validate(LaTeXFeatures &) const; /// - void addPreview(graphics::PreviewLoader &) const; + void addPreview(DocIterator const &, graphics::PreviewLoader &) const; /// - void addToToc(ParConstIterator const &) const; + void addToToc(DocIterator const &); /// - void updateLabels(ParIterator const &); - /// child document can be embedded - void registerEmbeddedFiles(EmbeddedFileList &) const; + void updateBuffer(ParIterator const &, UpdateType); /// - void updateEmbeddedFile(EmbeddedFile const & file); + docstring contextMenu(BufferView const & bv, int x, int y) const; + //@} + + /// \name Static public methods obligated for InsetCommand derived classes + //@{ /// 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); + //@} + protected: - InsetInclude(InsetInclude const &); /// - void doDispatch(Cursor & cur, FuncRequest & cmd); -private: - Inset * clone() const { return new InsetInclude(*this); } + InsetInclude(InsetInclude const &); +private: /** 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); + /// + bool isChildIncluded() const; + /// \name Private functions inherited from Inset class + //@{ + Inset * clone() const { return new InsetInclude(*this); } + /// + void doDispatch(Cursor & cur, FuncRequest & cmd); + /// + bool getStatus(Cursor & cur, FuncRequest const & cmd, FuncStatus &) const; + //@} + + /// \name Private functions inherited from InsetCommand class + //@{ /// set the parameters + // FIXME:InsetCommmand::setParams is not virtual void setParams(InsetCommandParams const & params); /// get the text displayed on the button 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 loaded Buffer or zero if the file loading did not proceed. -Buffer * loadIfNeeded(Buffer const & parent, InsetCommandParams const & params); } // namespace lyx -#endif // INSETINCLUDE_H +#endif // INSET_INCLUDE_H