/**
* \file FormMathsMatrix.C
- * Copyright 2001 The LyX Team.
- * See the file COPYING.
+ * This file is part of LyX, the document processor.
+ * Licence details can be found in the file COPYING.
*
* \author Alejandro Aguilar Sierra
- * \author Pablo De Napoli, pdenapo@dm.uba.ar
- * \author John Levon, moz@compsoc.man.ac.uk
- * \author Angus Leeming, a.leeming@ic.ac.uk
+ * \author Pablo De Napoli
+ * \author John Levon
+ * \author Angus Leeming
+ *
+ * Full author contact details are available in file CREDITS
*/
#include <config.h>
-#ifdef __GNUG__
-#pragma implementation
-#endif
-
-#include <algorithm>
#include "FormMathsMatrix.h"
#include "forms/form_maths_matrix.h"
-#include "Dialogs.h"
-#include "frontends/LyXView.h"
-#include "Lsstream.h"
-#include "lyxfunc.h"
+#include "ControlMath.h"
+#include "xformsBC.h"
+#include "ButtonController.h"
+
#include "support/LAssert.h"
#include "support/lyxalgo.h" // lyx::count
+
+#include "Lsstream.h"
+
#include FORMS_H_LOCATION
+#include <algorithm>
+
#ifndef CXX_GLOBAL_CSTD
using std::strlen;
#endif
}
-FormMathsMatrix::FormMathsMatrix(LyXView * lv, Dialogs * d,
- FormMathsPanel const & p)
- : FormMathsSub(lv, d, p, _("Maths Matrix"), false)
-{}
-
+typedef FormCB<ControlMathSub, FormDB<FD_maths_matrix> > base_class;
-FL_FORM * FormMathsMatrix::form() const
-{
- if (dialog_.get())
- return dialog_->form;
- return 0;
-}
+FormMathsMatrix::FormMathsMatrix()
+ : base_class(_("Maths Matrix"), false)
+{}
void FormMathsMatrix::build()
C_FormMathsMatrixAlignFilter);
setPrehandler(dialog_->input_halign);
- bc().setOK(dialog_->button_ok);
- bc().setApply(dialog_->button_apply);
- bc().setCancel(dialog_->button_close);
+ bcview().setOK(dialog_->button_ok);
+ bcview().setApply(dialog_->button_apply);
+ bcview().setCancel(dialog_->button_close);
- bc().addReadOnly(dialog_->slider_rows);
- bc().addReadOnly(dialog_->slider_columns);
- bc().addReadOnly(dialog_->choice_valign);
- bc().addReadOnly(dialog_->input_halign);
+ bcview().addReadOnly(dialog_->slider_rows);
+ bcview().addReadOnly(dialog_->slider_columns);
+ bcview().addReadOnly(dialog_->choice_valign);
+ bcview().addReadOnly(dialog_->input_halign);
}
int const nx = int(fl_get_slider_value(dialog_->slider_columns) + 0.5);
int const ny = int(fl_get_slider_value(dialog_->slider_rows) + 0.5);
- ostringstream ost;
- ost << nx << ' ' << ny << ' ' << c << ' ' << sh;
+ ostringstream os;
+ os << nx << ' ' << ny << ' ' << c << ' ' << sh;
+ controller().dispatchFunc(LFUN_INSERT_MATRIX, STRCONV(os.str()));
+}
+
- // remeber gcc 3.1 and lyxstring stringstream before "fixing"
- lv_->getLyXFunc()->dispatch(LFUN_INSERT_MATRIX, string(ost.str().c_str()));
+void FormMathsMatrix::update()
+{
+ bc().valid();
}
-bool FormMathsMatrix::input(FL_OBJECT * ob, long)
+
+ButtonPolicy::SMInput FormMathsMatrix::input(FL_OBJECT * ob, long)
{
if (ob == dialog_->choice_valign ||
- ob == dialog_->slider_rows) return true;
+ ob == dialog_->slider_rows) return ButtonPolicy::SMI_VALID;
int const nx = int(fl_get_slider_value(dialog_->slider_columns)+0.5);
for (int i = 0; i < nx; ++i)
fl_set_input(dialog_->input_halign, h_align_str);
fl_redraw_object(dialog_->input_halign);
- return true;
+ return ButtonPolicy::SMI_VALID;
}
int FormMathsMatrix::AlignFilter(char const * cur, int c)
{
- size_t len = strlen(cur);
+ size_t const len = strlen(cur);
- int const n = int(fl_get_slider_value(dialog_->slider_columns) + 0.5) -
- int(len) +
- int(lyx::count(cur, cur + len, '|'));
+ int const n = int(fl_get_slider_value(dialog_->slider_columns) + 0.5)
+ - int(len)
+ + int(lyx::count(cur, cur + len, '|'));
if (n < 0)
return FL_INVALID;