]> git.lyx.org Git - lyx.git/blobdiff - src/insets/insetbranch.h
changelogs
[lyx.git] / src / insets / insetbranch.h
index dc42e85a48f0e59c5639134e83f3ca73809b7027..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);
        ///
-       string branch;
-       /// Hack -- MV
-       BranchList branchlist;
- };
+       std::string branch;
+};
 
 
 /** The Branch inset for alternative, conditional output.
 class InsetBranch : public InsetCollapsable {
 public:
        ///
-
-
-       InsetBranch(BufferParams const &, string const &);
-       /// Copy constructor
-       InsetBranch(InsetBranch const &);
+       InsetBranch(BufferParams const &, InsetBranchParams const &);
        ///
        ~InsetBranch();
        ///
-       virtual std::auto_ptr<InsetBase> clone() const;
-       ///
-       string const editMessage() const;
+       std::string const editMessage() const;
        ///
        InsetOld::Code lyxCode() const { return InsetOld::BRANCH_CODE; }
        ///
@@ -56,16 +52,17 @@ public:
        ///
        bool showInsetDialog(BufferView *) const;
        ///
-       dispatch_result localDispatch(FuncRequest const &);
-       ///
        int latex(Buffer const &, std::ostream &,
-                       LatexRunParams const &) const;
+                       OutputParams const &) const;
        ///
-       int linuxdoc(Buffer const &, std::ostream &) const;
+       int linuxdoc(Buffer const &, std::ostream &,
+                    OutputParams const &) const;
        ///
-       int docbook(Buffer const &, std::ostream &, bool) const;
+       int docbook(Buffer const &, std::ostream &,
+                   OutputParams const & runparams) const;
        ///
-       int ascii(Buffer const &, std::ostream &, int) const;
+       int plaintext(Buffer const &, std::ostream &,
+                 OutputParams const & runparams) const;
        ///
        void validate(LaTeXFeatures &) const;
        ///
@@ -73,9 +70,19 @@ public:
        ///
        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:
+       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();
        ///
@@ -87,21 +94,21 @@ private:
 class InsetBranchMailer : public MailInset {
 public:
        ///
-       InsetBranchMailer(string const & name, InsetBranch & inset);
+       InsetBranchMailer(InsetBranch & inset);
        ///
        virtual InsetBase & inset() const { return inset_; }
        ///
-       virtual string const & name() const { return name_; }
+       virtual std::string const & name() const { return name_; }
        ///
-       virtual string const inset2string(Buffer const &) const;
+       virtual std::string const inset2string(Buffer const &) const;
        ///
-       static string const params2string(string const &, InsetBranchParams const &);
+       static std::string const params2string(InsetBranchParams const &);
        ///
-       static void string2params(string const &, InsetBranchParams &);
+       static void string2params(std::string const &, InsetBranchParams &);
 
 private:
        ///
-       string const name_;
+       static std::string const name_;
        ///
        InsetBranch & inset_;
 };