]> git.lyx.org Git - lyx.git/blobdiff - src/insets/insetbranch.h
changelogs
[lyx.git] / src / insets / insetbranch.h
index 65a3d1194ce7079cf682a6b35242ac1c30f06d55..9d5d3cd48ce0fe65a6c8c1b457b5c915c62b19c3 100644 (file)
 
 
 #include "insetcollapsable.h"
-#include "BranchList.h"
 
- struct InsetBranchParams {
+class BranchList;
+
+
+struct InsetBranchParams {
+       explicit InsetBranchParams(std::string const & b = std::string())
+               : branch(b) {}
        ///
        void write(std::ostream & os) const;
        ///
        void read(LyXLex & lex);
        ///
        std::string branch;
-       /// Hack -- MV
-       BranchList branchlist;
- };
+};
 
 
 /** The Branch inset for alternative, conditional output.
 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<InsetBase> clone() const;
-       ///
        std::string const editMessage() const;
        ///
        InsetOld::Code lyxCode() const { return InsetOld::BRANCH_CODE; }
@@ -57,30 +53,36 @@ public:
        bool showInsetDialog(BufferView *) const;
        ///
        int latex(Buffer const &, std::ostream &,
-                       LatexRunParams const &) const;
+                       OutputParams const &) const;
        ///
        int linuxdoc(Buffer const &, std::ostream &,
-                    LatexRunParams const &) const;
+                    OutputParams const &) const;
        ///
        int docbook(Buffer const &, std::ostream &,
-                   LatexRunParams const & runparams) const;
+                   OutputParams const & runparams) const;
        ///
-       int ascii(Buffer const &, std::ostream &,
-                 LatexRunParams const & runparams) const;
+       int plaintext(Buffer const &, std::ostream &,
+                 OutputParams const & runparams) const;
        ///
        void validate(LaTeXFeatures &) const;
        ///
        InsetBranchParams const & params() const { return params_; }
        ///
        void setParams(InsetBranchParams const & params) { params_ = params; }
+
+       /** \returns true if params_.branch is listed as 'selected' in
+           \c branchlist.
+        */
+       bool isBranchSelected(BranchList const & branchlist) const;
+
 protected:
-       ///
-       virtual
-       DispatchResult
-       priv_dispatch(FuncRequest const &, idx_type &, pos_type &);
+       InsetBranch(InsetBranch const &);
+       virtual void doDispatch(LCursor & cur, FuncRequest & cmd);
 private:
        friend class InsetBranchParams;
 
+       virtual std::auto_ptr<InsetBase> doClone() const;
+
        /// used by the constructors
        void init();
        ///
@@ -92,7 +94,7 @@ private:
 class InsetBranchMailer : public MailInset {
 public:
        ///
-       InsetBranchMailer(std::string const & name, InsetBranch & inset);
+       InsetBranchMailer(InsetBranch & inset);
        ///
        virtual InsetBase & inset() const { return inset_; }
        ///
@@ -100,13 +102,13 @@ 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_;
 };