]> git.lyx.org Git - lyx.git/blobdiff - src/insets/insetbranch.h
changelogs
[lyx.git] / src / insets / insetbranch.h
index 6da8766643c7b49afdda6f06ba14c9e34a23970c..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; }
@@ -71,14 +69,20 @@ public:
        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();
        ///