// -*- C++ -*- /** * \file InsetInclude.h * This file is part of LyX, the document processor. * Licence details can be found in the file COPYING. * * \author Lars Gullik Bjønnes * \author Richard Heck (conversion to InsetCommand) * * Full author contact details are available in file CREDITS. */ #ifndef INSET_INCLUDE_H #define INSET_INCLUDE_H #include "InsetCommand.h" #include "RenderButton.h" #include "support/unique_ptr.h" 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 { // Disable assignment operator, since it is not used, and cannot be // implemented consistently with the copy constructor, because // include_label is const. InsetInclude & operator=(InsetInclude const &); public: /// 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(); /// void updateCommand(); /// void write(std::ostream &) const; /// \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; /// void draw(PainterInfo & pi, int x, int y) const; /// DisplayType display() const; /// InsetCode lyxCode() const { return INCLUDE_CODE; } /// docstring layoutName() const; /** Fills \c key * \param keys the list of bibkeys in the child buffer. * \param it not used here */ void collectBibKeys(InsetIterator const &, support::FileNameList &) const; /// bool hasSettings() const { return true; } /// void latex(otexstream &, OutputParams const &) const; /// int plaintext(odocstringstream & ods, OutputParams const & op, size_t max_length = INT_MAX) const; /// int docbook(odocstream &, OutputParams const &) const; /// docstring xhtml(XHTMLStream &, OutputParams const &) const; /// void validate(LaTeXFeatures &) const; /// void addPreview(DocIterator const &, graphics::PreviewLoader &) const; /// void addToToc(DocIterator const & di, bool output_active, UpdateType utype, TocBackend & backend) const; /// void updateBuffer(ParIterator const &, UpdateType); /// std::string contextMenuName() const; //@} /// \name Static public methods obligated for InsetCommand derived classes //@{ /// static ParamInfo const & findInfo(std::string const &); /// static std::string defaultCommand() { return "include"; } /// static bool isCompatibleCommand(std::string const & s); /// bool needsCProtection(bool const maintext = false, bool const fragile = false) const; //@} protected: /// 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; /// check whether the included file exist bool includedFileExist() 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. unique_ptr const preview_; /// mutable bool failedtoload_; /// cache mutable bool set_label_; mutable RenderButton button_; mutable docstring listings_label_; InsetLabel * label_; mutable Buffer * child_buffer_; mutable bool file_exist_; }; } // namespace lyx #endif // INSET_INCLUDE_H