* ======================================================
*
* 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, boost::noncopyable {
public:
+ /// the type of inclusion
+ enum Flags {
+ ///
+ INCLUDE = 0,
+ ///
+ VERB = 1,
+ ///
+ INPUT = 2,
+ ///
+ VERBAST = 3
+ };
+
+ struct Params {
+ Params(InsetCommandParams const & cp = InsetCommandParams(),
+ Flags f = INCLUDE,
+ bool nl = false,
+ string const & name = string())
+ : cparams(cp), flag(f), noload(nl),
+ masterFilename_(name) {}
+ InsetCommandParams cparams;
+ Flags flag;
+ bool noload;
+ string masterFilename_;
+
+ ///
+ bool operator==(Params const &) const;
+ ///
+ bool operator!=(Params const &) const;
+ };
+
///
- InsetInclude(): InsetCommand("include")
- {
- flag = InsetInclude::INCLUDE;
- }
+ InsetInclude(Params const &);
///
- InsetInclude(string const &, Buffer *);
+ InsetInclude(InsetCommandParams const &, Buffer const &);
///
~InsetInclude();
- ///
- InsetInclude * Clone() const;
+
+ /// get the parameters
+ Params const & params(void) const;
+ /// set the parameters
+ void set(Params const & params);
+
+ ///
+ virtual Inset * clone(Buffer const &, bool same_id = false) const;
///
- Inset::Code LyxCode() const { return Inset::INCLUDE_CODE; }
- /// This is 1 if the childs have labels, 0 otherwise
- int GetNumberOfLabels() const;
+ Inset::Code lyxCode() const { return Inset::INCLUDE_CODE; }
/// 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(BufferView *, int x, int y, unsigned int button);
///
- void Edit(int, int);
+ void edit(BufferView * bv, bool front = true);
///
- 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 Read(LyXLex &);
- ///
- int Latex(FILE * file, signed char fragile);
+ /// With lyx3 we won't overload these 3 methods
+ void write(Buffer const *, std::ostream &) const;
///
- int Latex(string & file, signed char fragile);
-
+ void read(Buffer const *, LyXLex &);
///
- void Validate(LaTeXFeatures &) const;
-
- /// Input inserts anything inside a paragraph, Display can give some visual feedback
- bool display() const { return !(isInput()); }
+ int latex(Buffer const *, std::ostream &,
+ bool fragile, bool free_spc) const;
///
- string getScreenLabel() const;
+ int ascii(Buffer const *, std::ostream &, int linelen) 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 linuxdoc(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();
+ int docbook(Buffer const *, std::ostream &) const;
///
- void setVisibleSpace(bool b);
- /// return true if the file is or got loaded.
- bool loadIfNeeded() const;
-private:
- ///
- enum Include_Flags {
- ///
- INCLUDE= 0,
- ///
- VERB = 1,
- ///
- INPUT = 2,
- ///
- VERBAST = 3
- };
-
- ///
- bool noload;
- ///
- int flag;
- ///
- Buffer * master;
- ///
- string filename;
-};
+ void validate(LaTeXFeatures &) const;
+ /** Input inserts anything inside a paragraph.
+ Display can give some visual feedback
+ */
+ bool display() const;
-inline
-bool InsetInclude::isVerb() const
-{
- return (bool)(flag == InsetInclude::VERB || flag == InsetInclude::VERBAST);
-}
-
+ /// return the filename stub of the included file
+ string const getRelFileBaseName() const;
-inline
-void InsetInclude::setInput()
-{
- if (!isInput()) {
- flag = InsetInclude::INPUT;
- setCmdName("input");
- }
-}
+ /// return true if the included file is not loaded
+ bool isIncludeOnly() const;
+ /// return true if the file is or got loaded.
+ bool loadIfNeeded() const;
-inline
-void InsetInclude::setNoLoad(bool b)
-{
- noload = b;
-}
+ /// hide a dialog if about
+ SigC::Signal0<void> hideDialog;
+private:
+ /// get the text displayed on the button
+ string const getScreenLabel(Buffer const *) 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
+ Params params_;
+ /// holds the entity name that defines the file location (SGML)
+ string const include_label;
+};
-inline
-void InsetInclude::setInclude()
+inline bool InsetInclude::isVerbatim() const
{
- if (!isInclude()) {
- flag = InsetInclude::INCLUDE;
- setCmdName("include");
- }
+ return params_.flag == VERB || params_.flag == VERBAST;
}
-inline
-void InsetInclude::setVerb()
-{
- if (!isVerb()) {
- flag = InsetInclude::VERB;
- setCmdName("verbatiminput");
- }
-}
-
-
-inline
-void InsetInclude::setVisibleSpace(bool b)
+inline bool InsetInclude::isIncludeOnly() const
{
- if (b && flag == InsetInclude::VERB) {
- setCmdName("verbatiminput*");
- flag = InsetInclude::VERBAST;
- } else if (!b && flag == InsetInclude::VERBAST) {
- setCmdName("verbatiminput");
- flag = InsetInclude::VERB;
- }
+ return params_.flag == INCLUDE && params_.noload;
}
+
#endif