]> git.lyx.org Git - lyx.git/blobdiff - src/trans_mgr.C
* src/tabular.[Ch]: simplify plaintext methods, because there
[lyx.git] / src / trans_mgr.C
index 58a1c1874e7a98b750cb376136a06ab2bf1aea06..d3fb833abcc1bdc759295aa38af82749fa92329a 100644 (file)
@@ -13,6 +13,7 @@
 
 #include "trans_mgr.h"
 
+#include "buffer.h"
 #include "BufferView.h"
 #include "CutAndPaste.h"
 #include "cursor.h"
 #include "lyxtext.h"
 #include "trans.h"
 
-#include "insets/insetlatexaccent.h"
-
 #include "support/lstrings.h"
 
-using lyx::support::split;
+
+namespace lyx {
+
+using support::split;
 
 using std::endl;
 using std::string;
@@ -202,21 +204,21 @@ TransManager::~TransManager()
 {}
 
 
-int TransManager::SetPrimary(string const & language)
+int TransManager::setPrimary(string const & language)
 {
-       if (t1_->GetName() == language)
+       if (t1_->getName() == language)
                return 0;
 
-       return t1_->Load(language);
+       return t1_->load(language);
 }
 
 
-int TransManager::SetSecondary(string const & language)
+int TransManager::setSecondary(string const & language)
 {
-       if (t2_->GetName() == language)
+       if (t2_->getName() == language)
                return 0;
 
-       return t2_->Load(language);
+       return t2_->load(language);
 }
 
 
@@ -226,31 +228,31 @@ bool TransManager::setCharset(string const & str)
 }
 
 
-void TransManager::EnablePrimary()
+void TransManager::enablePrimary()
 {
-       if (t1_->IsDefined())
+       if (t1_->isDefined())
                active_ = t1_.get();
 
        lyxerr[Debug::KBMAP] << "Enabling primary keymap" << endl;
 }
 
 
-void TransManager::EnableSecondary()
+void TransManager::enableSecondary()
 {
-       if (t2_->IsDefined())
+       if (t2_->isDefined())
                active_ = t2_.get();
        lyxerr[Debug::KBMAP] << "Enabling secondary keymap" << endl;
 }
 
 
-void TransManager::DisableKeymap()
+void TransManager::disableKeymap()
 {
        active_ = &default_;
        lyxerr[Debug::KBMAP] << "Disabling keymap" << endl;
 }
 
 
-void  TransManager::TranslateAndInsert(char c, LyXText * text)
+void  TransManager::translateAndInsert(char c, LyXText * text, LCursor & cur)
 {
        string res = active_->process(c, *this);
 
@@ -259,19 +261,19 @@ void  TransManager::TranslateAndInsert(char c, LyXText * text)
 
        while (res.length() > 0) {
                res = split(res, temp, TransState::TOKEN_SEP);
-               insert(temp, text);
+               insert(temp, text, cur);
        }
 }
 
 
-void TransManager::insertVerbatim(string const & str, LyXText * text)
+void TransManager::insertVerbatim(string const & str, LyXText * text, LCursor & cur)
 {
        for (string::size_type i = 0, n = str.size(); i < n; ++i)
-               text->insertChar(text->bv()->cursor(), str[i]);
+               text->insertChar(cur, str[i]);
 }
 
 
-void TransManager::insert(string const & str, LyXText * text)
+void TransManager::insert(string const & str, LyXText * text, LCursor & cur)
 {
        // Go through the character encoding only if the current
        // encoding (chset_->name()) matches the current font_norm
@@ -283,23 +285,15 @@ void TransManager::insert(string const & str, LyXText * text)
        if (chset_.getName() != lyxrc.font_norm ||
            !enc.first) {
                // Could not find an encoding
-               InsetLatexAccent ins(str);
-               if (ins.canDisplay()) {
-                       LCursor & cur = text->bv()->cursor();
-                       lyx::cap::replaceSelection(cur);
-                       cur.insert(new InsetLatexAccent(ins));
-                       cur.posRight();
-               } else {
-                       insertVerbatim(str, text);
-               }
+               insertVerbatim(str, text, cur);
                return;
        }
        string const tmp(1, static_cast<char>(enc.second));
-       insertVerbatim(tmp, text);
+       insertVerbatim(tmp, text, cur);
 }
 
 
-void TransManager::deadkey(char c, tex_accent accent, LyXText * t)
+void TransManager::deadkey(char c, tex_accent accent, LyXText * t, LCursor & cur)
 {
        if (c == 0 && active_ != &default_) {
                // A deadkey was pressed that cannot be printed
@@ -308,7 +302,7 @@ void TransManager::deadkey(char c, tex_accent accent, LyXText * t)
                if (active_->isAccentDefined(accent, i) == true) {
                        string const res = trans_fsm_
                                .currentState->deadkey(c, i);
-                       insert(res, t);
+                       insert(res, t, cur);
                        return;
                }
        }
@@ -318,9 +312,12 @@ void TransManager::deadkey(char c, tex_accent accent, LyXText * t)
                i.accent = accent;
                i.data.erase();
                string res = trans_fsm_.currentState->deadkey(c, i);
-               insert(res, t);
+               insert(res, t, cur);
        } else {
                // Go through the translation
-               TranslateAndInsert(c, t);
+               translateAndInsert(c, t, cur);
        }
 }
+
+
+} // namespace lyx