* ======================================================
*
* LyX, The Document Processor
- *
- * Copyright (C) 1997 LyX Team (this file was created this year)
- *
+ *
+ * Copyright 1997 LyX Team (this file was created this year)
+ *
* ====================================================== */
#ifndef INSET_INCLUDE_H
#endif
#include "insetcommand.h"
-#include "buffer.h"
-#include "support/filetools.h"
+class Buffer;
struct LaTeXFeatures;
// Created by AAS 970521
/** Used to include files
*/
-class InsetInclude: public InsetCommand {
+class InsetInclude: public InsetButton, public noncopyable {
public:
+ /// the type of inclusion
+ enum IncludeFlags {
+ ///
+ INCLUDE= 0,
+ ///
+ VERB = 1,
+ ///
+ INPUT = 2,
+ ///
+ VERBAST = 3
+ };
+
+ struct InsetIncludeParams {
+ InsetIncludeParams(InsetCommandParams const & cp = InsetCommandParams(),
+ IncludeFlags f = INCLUDE, bool nl = false, Buffer const * b = 0)
+ : cparams(cp), flag(f), noload(nl), buffer(b) {}
+ InsetCommandParams cparams;
+ IncludeFlags flag;
+ bool noload;
+ Buffer const * buffer;
+ };
+
///
- InsetInclude(): InsetCommand("include")
- {
- flag = InsetInclude::INCLUDE;
- }
+ InsetInclude(InsetIncludeParams const &);
///
- InsetInclude(string const &, Buffer *);
+ InsetInclude(InsetCommandParams const &, Buffer const &);
///
~InsetInclude();
+
+ /// get the parameters
+ InsetIncludeParams const & params(void) const;
+
+ /// set the parameters
+ void setFromParams(InsetIncludeParams const & params);
+
///
- Inset * Clone();
+ Inset * Clone(Buffer const &) const;
///
Inset::Code LyxCode() const { return Inset::INCLUDE_CODE; }
- /// This is 1 if the childs have labels, 0 otherwise
- int GetNumberOfLabels() const;
/// This returns the list of labels on the child buffer
- string getLabel(int) const;
+ std::vector<string> const getLabelList() const;
/// This returns the list of bibkeys on the child buffer
- string getKeys() const;
+ std::vector< std::pair<string,string> > const getKeys() const;
///
- void Edit(int, int);
+ void Edit(BufferView *, int x, int y, unsigned int button);
///
- unsigned char Editable() const
+ EDITABLE Editable() const
{
- return 1;
+ return IS_EDITABLE;
}
/// With lyx3 we won't overload these 3 methods
- void Write(FILE *);
+ void Write(Buffer const *, std::ostream &) const;
///
- void Read(LyXLex &);
- ///
- int Latex(FILE * file, signed char fragile);
+ void Read(Buffer const *, LyXLex &);
///
- int Latex(string & file, signed char fragile);
-
+ int Latex(Buffer const *, std::ostream &, bool fragile, bool free_spc) const;
///
- void Validate(LaTeXFeatures &) const;
-
- /// Input inserts anything inside a paragraph, Display can give some visual feedback
- bool Display() const { return !(isInput()); }
+ int Ascii(Buffer const *, std::ostream &, int linelen) const;
///
- string getScreenLabel() const;
+ int Linuxdoc(Buffer const *, std::ostream &) const;
///
- void setContents(string const & c) {
- InsetCommand::setContents(c);
- filename = MakeAbsPath(contents,
- OnlyPath(getMasterFilename()));
- }
- ///
- void setFilename(string const & n) { setContents(n); }
- ///
- string getMasterFilename() const { return master->getFileName(); }
- ///
- string getFileName() const {
- return filename;
- }
- /// In "input" mode uses \input instead of \include.
- bool isInput() const { return flag == InsetInclude::INPUT; }
- /// If this is true, the child file shouldn't be loaded by lyx
- bool isNoLoad() const { return noload; }
-
- /** A verbatim file shouldn't be loaded by LyX
- * No need to generate LaTeX code of a verbatim file
- */
- bool isVerb() const;
+ int DocBook(Buffer const *, std::ostream &) const;
///
- bool isVerbVisibleSpace() const { return flag == InsetInclude::VERBAST;}
- ///
- bool isInclude() const { return flag == InsetInclude::INCLUDE;}
- ///
- void setInput();
- ///
- void setNoLoad(bool);
- ///
- void setInclude();
- ///
- void setVerb();
- ///
- void setVisibleSpace(bool b);
+ void Validate(LaTeXFeatures &) const;
+
+ /** Input inserts anything inside a paragraph.
+ Display can give some visual feedback
+ */
+ bool display() const;
+
+ /// return the filename stub of the included file
+ string const getRelFileBaseName() const;
+
+ /// return true if the included file is not loaded
+ bool isIncludeOnly() const;
+
/// return true if the file is or got loaded.
bool loadIfNeeded() const;
+
+ /// hide a dialog if about
+ Signal0<void> hideDialog;
private:
- ///
- enum Include_Flags {
- ///
- INCLUDE= 0,
- ///
- VERB = 1,
- ///
- INPUT = 2,
- ///
- VERBAST = 3
- };
-
- ///
- bool noload;
+ /// get the text displayed on the button
+ string const getScreenLabel() const;
+ /// is this a verbatim include ?
+ bool isVerbatim() const;
+ /// get the filename of the master buffer
+ string const getMasterFilename() const;
+ /// get the included file name
+ string const getFileName() const;
+
+ /// the parameters
+ InsetIncludeParams params_;
///
- int flag;
- ///
- Buffer * master;
- ///
- string filename;
+ string include_label;
};
-inline
-bool InsetInclude::isVerb() const
+inline bool InsetInclude::isVerbatim() const
{
- return (bool)(flag == InsetInclude::VERB || flag == InsetInclude::VERBAST);
+ return params_.flag == VERB || params_.flag == VERBAST;
}
-inline
-void InsetInclude::setInput()
+inline bool InsetInclude::isIncludeOnly() const
{
- if (!isInput()) {
- flag = InsetInclude::INPUT;
- setCmdName("input");
- }
+ return params_.flag == INCLUDE && params_.noload;
}
-
-inline
-void InsetInclude::setNoLoad(bool b)
-{
- noload = b;
-}
-
-
-inline
-void InsetInclude::setInclude()
-{
- if (!isInclude()) {
- flag = InsetInclude::INCLUDE;
- setCmdName("include");
- }
-}
-
-
-inline
-void InsetInclude::setVerb()
-{
- if (!isVerb()) {
- flag = InsetInclude::VERB;
- setCmdName("verbatiminput");
- }
-}
-
-
-inline
-void InsetInclude::setVisibleSpace(bool b)
-{
- if (b && flag == InsetInclude::VERB) {
- setCmdName("verbatiminput*");
- flag = InsetInclude::VERBAST;
- } else if (!b && flag == InsetInclude::VERBAST) {
- setCmdName("verbatiminput");
- flag = InsetInclude::VERB;
- }
-}
#endif