X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Ftrans_mgr.C;h=8641876c23feea51bef3844813dba0b9f0693f8f;hb=ae348f8af96100a154b3792d27732d621d44ec89;hp=6fa53197099e6e97e1595eadf917aac04cd5c374;hpb=44cd0fc9a1687cc63911c7f98d978594458e7813;p=lyx.git diff --git a/src/trans_mgr.C b/src/trans_mgr.C index 6fa5319709..8641876c23 100644 --- a/src/trans_mgr.C +++ b/src/trans_mgr.C @@ -12,11 +12,17 @@ #include #include "trans_mgr.h" -#include "trans.h" -#include "lyxtext.h" + +#include "BufferView.h" +#include "CutAndPaste.h" +#include "cursor.h" #include "debug.h" -#include "insets/insetlatexaccent.h" #include "lyxrc.h" +#include "lyxtext.h" +#include "trans.h" + +#include "insets/insetlatexaccent.h" + #include "support/lstrings.h" using lyx::support::split; @@ -191,28 +197,26 @@ TransManager::TransManager() {} +// For the sake of boost::scoped_ptr. TransManager::~TransManager() -{ - delete t1_; - delete t2_; -} +{} -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); } @@ -222,31 +226,31 @@ bool TransManager::setCharset(string const & str) } -void TransManager::EnablePrimary() +void TransManager::enablePrimary() { - if (t1_->IsDefined()) - active_ = t1_; + if (t1_->isDefined()) + active_ = t1_.get(); lyxerr[Debug::KBMAP] << "Enabling primary keymap" << endl; } -void TransManager::EnableSecondary() +void TransManager::enableSecondary() { - if (t2_->IsDefined()) - active_ = t2_; + 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) { string res = active_->process(c, *this); @@ -262,11 +266,8 @@ void TransManager::TranslateAndInsert(char c, LyXText * text) void TransManager::insertVerbatim(string const & str, LyXText * text) { - string::size_type const l = str.length(); - - for (string::size_type i = 0; i < l; ++i) { - text->insertChar(str[i]); - } + for (string::size_type i = 0, n = str.size(); i < n; ++i) + text->insertChar(text->bv()->cursor(), str[i]); } @@ -284,15 +285,16 @@ void TransManager::insert(string const & str, LyXText * text) // Could not find an encoding InsetLatexAccent ins(str); if (ins.canDisplay()) { - text->insertInset( - new InsetLatexAccent(ins)); + LCursor & cur = text->bv()->cursor(); + lyx::cap::replaceSelection(cur); + cur.insert(new InsetLatexAccent(ins)); + cur.posRight(); } else { insertVerbatim(str, text); } return; } - string tmp; - tmp += static_cast(enc.second); + string const tmp(1, static_cast(enc.second)); insertVerbatim(tmp, text); } @@ -319,6 +321,6 @@ void TransManager::deadkey(char c, tex_accent accent, LyXText * t) insert(res, t); } else { // Go through the translation - TranslateAndInsert(c, t); + translateAndInsert(c, t); } }