]> git.lyx.org Git - lyx.git/blobdiff - src/insets/InsetInclude.h
Remove TextClassPtr without losing the type safety it provided.
[lyx.git] / src / insets / InsetInclude.h
index 50e95babc7722a18969567b4d6801fdc869e19f0..e715b8b4a62012ec0229b294f8bbcdaa74dad5f7 100644 (file)
@@ -21,8 +21,6 @@
 #include "Counters.h"
 #include "EmbeddedFiles.h"
 
-#include "support/FileName.h"
-
 #include <boost/scoped_ptr.hpp>
 
 namespace lyx {
@@ -32,7 +30,6 @@ class Dimension;
 class LaTeXFeatures;
 class RenderMonitoredPreview;
 
-
 /// for including tex/lyx files
 class InsetInclude : public InsetCommand {
 public:
@@ -51,15 +48,13 @@ public:
         *  \param buffer the Buffer containing this inset.
         *  \param list the list of labels in the child buffer.
         */
-       void getLabelList(Buffer const & buffer,
-                         std::vector<docstring> & list) const;
+       void getLabelList(std::vector<docstring> & 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).
@@ -67,37 +62,36 @@ 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.
         */
-       std::vector<support::FileName> const &
+       EmbeddedFileList const &
                getBibfilesCache(Buffer const & buffer) const;
        ///
        EDITABLE editable() const { return IS_EDITABLE; }
        ///
-       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(ParConstIterator const &) const;
        ///
-       void updateLabels(Buffer const & buffer, ParIterator const &);
+       void updateLabels(ParIterator const &);
        /// child document can be embedded
-       void registerEmbeddedFiles(Buffer const &, EmbeddedFiles &) const;
+       void registerEmbeddedFiles(EmbeddedFileList &) const;
+       ///
+       void updateEmbeddedFile(EmbeddedFile const & file);
        ///
-       static CommandInfo const * findInfo(std::string const &);
+       static ParamInfo const & findInfo(std::string const &);
        ///
        static std::string defaultCommand() { return "include"; };
        ///
@@ -105,9 +99,9 @@ public:
 protected:
        InsetInclude(InsetInclude const &);
        ///
-       virtual void doDispatch(Cursor & cur, FuncRequest & cmd);
+       void doDispatch(Cursor & cur, FuncRequest & cmd);
 private:
-       virtual Inset * clone() const;
+       Inset * clone() const;
 
        /** Slot receiving a signal that the external file has changed
         *  and the preview should be regenerated.
@@ -115,9 +109,9 @@ private:
        void fileChanged() const;
 
        /// 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;
 
@@ -130,7 +124,9 @@ private:
        mutable docstring listings_label_;
 };
 
-
+/// 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);