X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Finsets%2Finsetbranch.h;h=f39fe12707c25f5bcca7a09847972ae5fd1a7bc8;hb=e28331ed63062dea10d0a21b9ec12034b4b17b9a;hp=15945de5defbda8d9b1136d4672baa07aac055d0;hpb=b0eb70e869128e30ab7e4538aa32a244fd4cea57;p=lyx.git diff --git a/src/insets/insetbranch.h b/src/insets/insetbranch.h index 15945de5de..f39fe12707 100644 --- a/src/insets/insetbranch.h +++ b/src/insets/insetbranch.h @@ -12,20 +12,25 @@ #ifndef INSETBRANCH_H #define INSETBRANCH_H - #include "insetcollapsable.h" -#include "BranchList.h" +#include "mailinset.h" + + +namespace lyx { + +class Buffer; - struct InsetBranchParams { +class InsetBranchParams { +public: + explicit InsetBranchParams(docstring const & b = docstring()) + : branch(b) {} /// void write(std::ostream & os) const; /// void read(LyXLex & lex); /// - std::string branch; - /// Hack -- MV - BranchList branchlist; - }; + docstring branch; +}; /** The Branch inset for alternative, conditional output. @@ -34,19 +39,13 @@ class InsetBranch : public InsetCollapsable { public: /// - - - InsetBranch(BufferParams const &, std::string const &); - /// Copy constructor - InsetBranch(InsetBranch const &); + InsetBranch(BufferParams const &, InsetBranchParams const &); /// ~InsetBranch(); /// - virtual std::auto_ptr clone() const; + virtual docstring const editMessage() const; /// - std::string const editMessage() const; - /// - InsetOld::Code lyxCode() const { return InsetOld::BRANCH_CODE; } + InsetBase::Code lyxCode() const { return InsetBase::BRANCH_CODE; } /// void write(Buffer const &, std::ostream &) const; /// @@ -56,40 +55,48 @@ public: /// bool showInsetDialog(BufferView *) const; /// - int latex(Buffer const &, std::ostream &, - LatexRunParams const &) const; + int latex(Buffer const &, odocstream &, OutputParams const &) const; /// - int linuxdoc(Buffer const &, std::ostream &) const; + int docbook(Buffer const &, odocstream &, + OutputParams const & runparams) const; /// - int docbook(Buffer const &, std::ostream &, bool) const; + int plaintext(Buffer const &, odocstream &, + OutputParams const & runparams) const; /// - int ascii(Buffer const &, std::ostream &, int) const; + void textString(Buffer const & buf, odocstream &) const; /// void validate(LaTeXFeatures &) const; /// InsetBranchParams const & params() const { return params_; } /// void setParams(InsetBranchParams const & params) { params_ = params; } -protected: + + /** \returns true if params_.branch is listed as 'selected' in + \c buffer. This handles the case of child documents. + */ + bool isBranchSelected(Buffer const & buffer) const; /// - virtual - DispatchResult - priv_dispatch(FuncRequest const &, idx_type &, pos_type &); + bool getStatus(LCursor &, FuncRequest const &, FuncStatus &) const; + +protected: + InsetBranch(InsetBranch const &); + virtual void doDispatch(LCursor & cur, FuncRequest & cmd); private: friend class InsetBranchParams; + virtual std::auto_ptr doClone() const; + /// used by the constructors void init(); /// InsetBranchParams params_; }; -#include "mailinset.h" class InsetBranchMailer : public MailInset { public: /// - InsetBranchMailer(std::string const & name, InsetBranch & inset); + InsetBranchMailer(InsetBranch & inset); /// virtual InsetBase & inset() const { return inset_; } /// @@ -97,17 +104,17 @@ public: /// virtual std::string const inset2string(Buffer const &) const; /// - static std::string const params2string(std::string const &, InsetBranchParams const &); + static std::string const params2string(InsetBranchParams const &); /// static void string2params(std::string const &, InsetBranchParams &); private: /// - std::string const name_; + static std::string const name_; /// InsetBranch & inset_; }; - +} // namespace lyx #endif