]> git.lyx.org Git - lyx.git/blobdiff - src/frontends/xforms/FormTexinfo.C
Change the semantics of 'none' and 'auto' viewers/editors: 'none' means now
[lyx.git] / src / frontends / xforms / FormTexinfo.C
index e67f351a5e9bf26533a20c753ecb52123b1d4eb8..98677ef2ce703776f2c2b5a200f43ff7dea1cb93 100644 (file)
@@ -3,32 +3,34 @@
  * This file is part of LyX, the document processor.
  * Licence details can be found in the file COPYING.
  *
- * \author Herbert Voss
+ * \author Herbert Voß
  *
- * Full author contact details are available in file CREDITS
- * \date 2001-10-01
+ * Full author contact details are available in file CREDITS.
  */
 
 #include <config.h>
-#include <fstream>
 
-
-#include "xformsBC.h"
 #include "FormTexinfo.h"
 #include "forms/form_texinfo.h"
+
 #include "Tooltips.h"
-#include "gettext.h"
-#include "xforms_helpers.h"
-#include "support/LAssert.h"
-#include "support/lstrings.h"
+#include "xformsBC.h"
+
+#include "support/filetools.h"
+
+#include "lyx_forms.h"
+
+using std::string;
+
+namespace lyx {
+
+namespace frontend {
 
-#include FORMS_H_LOCATION
 
-using std::vector;
+typedef FormController<ControlTexinfo, FormView<FD_texinfo> > base_class;
 
-typedef FormCB<ControlTexinfo, FormDB<FD_texinfo> > base_class;
-FormTexinfo::FormTexinfo()
-       : base_class(_("LaTeX Information")),
+FormTexinfo::FormTexinfo(Dialog & parent)
+       : base_class(parent, _("TeX Information")),
          activeStyle(ControlTexinfo::cls)
 {}
 
@@ -37,7 +39,8 @@ void FormTexinfo::build() {
        dialog_.reset(build_texinfo(this));
 
        // callback for double click in browser to view the selected file
-       fl_set_browser_dblclick_callback(dialog_->browser, C_FormBaseInputCB, 2);
+       fl_set_browser_dblclick_callback(dialog_->browser,
+                                        C_FormDialogView_InputCB, 2);
 
        string const classes_List = _("LaTeX classes|LaTeX styles|BibTeX styles");
        fl_addto_choice(dialog_->choice_classes, classes_List.c_str());
@@ -52,13 +55,15 @@ void FormTexinfo::build() {
        str = _("Show full path or only file name.");
        tooltips().init(dialog_->check_fullpath, str);
 
-       str = _("Runs the script \"TexFiles.sh\" to build new file lists.");
+       str = _("Runs the script \"TexFiles.sh\" to rebuild the file lists.");
        tooltips().init(dialog_->button_rescan, str);
 
        str = _("Double click to view contents of file.");
        tooltips().init(dialog_->browser, str);
+#if FL_VERSION == 0 || (FL_REVISION == 0 && FL_FIXLEVEL == 0)
        // Work-around xforms' bug; enable tooltips for browser widgets.
        setPrehandler(dialog_->browser);
+#endif
 
        str = _("Runs the script \"texhash\" which builds a new LaTeX tree. "
                "Needed if you install a new TeX class or style. You need write "
@@ -72,42 +77,30 @@ ButtonPolicy::SMInput FormTexinfo::input(FL_OBJECT * ob, long ob_value) {
        if (ob == dialog_->button_texhash) {
                // makes only sense if the rights are set well for
                // users (/var/lib/texmf/ls-R)
-               controller().runTexhash();
+               texhash();
                // texhash requires a rescan and an update of the styles
-               controller().rescanStyles();
+               rescanTexStyles();
                updateStyles(activeStyle);
 
 
        } else if (ob == dialog_->browser && ob_value == 2) {
                // double click in browser: view selected file
-               string selection = string();
-               if (fl_get_button(dialog_->check_fullpath)) {
-                       // contents in browser has full path
-                       selection = getString(dialog_->browser);
-               } else {
-                       // contents in browser has filenames without path
-                       // reconstruct path from controller getContents
-                       string const files = controller().getContents(activeStyle, true);
-                       vector<string> const vec = getVectorFromString(files, "\n");
-
-                       // find line in files vector
-                       vector<string>::const_iterator it = vec.begin();
-                       int const line = fl_get_browser(dialog_->browser);
-                       for (int i = line; it != vec.end() && i > 0; ++it, --i) {
-                               if (i == 1) selection = *it;
-                       }
-               }
-
-               if (!selection.empty()) {
-                       controller().viewFile(selection);
-               }
-
-               // reset the browser so that the following single-click callback doesn't do anything
+               ContentsType::size_type const sel = fl_get_browser(ob);
+               ContentsType const & data = texdata_[activeStyle];
+               string file = data[sel-1];
+               if (!fl_get_button(dialog_->check_fullpath))
+                       file = getTexFileFromList(data[sel-1],
+                               controller().getFileType(activeStyle));
+               if (sel >= 1 && sel <= data.size())
+                       controller().viewFile(file);
+
+               // reset the browser so that the following single-click
+               // callback doesn't do anything
                fl_deselect_browser(dialog_->browser);
 
        } else if (ob == dialog_->button_rescan) {
                // build new *Files.lst
-               controller().rescanStyles();
+               rescanTexStyles();
                updateStyles(activeStyle);
 
        } else if (ob == dialog_->check_fullpath) {
@@ -133,13 +126,18 @@ ButtonPolicy::SMInput FormTexinfo::input(FL_OBJECT * ob, long ob_value) {
 
 void FormTexinfo::updateStyles(ControlTexinfo::texFileSuffix whichStyle)
 {
-       fl_clear_browser(dialog_->browser);
-
+       ContentsType & data = texdata_[whichStyle];
        bool const withFullPath = fl_get_button(dialog_->check_fullpath);
+       getTexFileList(whichStyle, data, withFullPath);
 
-       string const str =
-               controller().getContents(whichStyle, withFullPath);
-       fl_add_browser_line(dialog_->browser, str.c_str());
+       fl_clear_browser(dialog_->browser);
+       ContentsType::const_iterator it  = data.begin();
+       ContentsType::const_iterator end = data.end();
+       for (; it != end; ++it)
+               fl_add_browser_line(dialog_->browser, (*it).c_str());
 
        activeStyle = whichStyle;
 }
+
+} // namespace frontend
+} // namespace lyx