X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Ftrans_mgr.C;h=ba9bb1e35fca87a347d251bfef5a8a79436537e3;hb=7f68b94d8a7fba6942890b7733403192b98b040a;hp=407507cd7e3cc51755a3454917e47b490c5f18b0;hpb=57a24ea9124812ddc5108ff1ad304ff61acc826a;p=lyx.git diff --git a/src/trans_mgr.C b/src/trans_mgr.C index 407507cd7e..ba9bb1e35f 100644 --- a/src/trans_mgr.C +++ b/src/trans_mgr.C @@ -12,17 +12,22 @@ #include #include "trans_mgr.h" -#include "trans.h" -#include "lyxtext.h" + +#include "BufferView.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; using std::endl; - +using std::string; using std::pair; @@ -191,11 +196,9 @@ TransManager::TransManager() {} +// For the sake of boost::scoped_ptr. TransManager::~TransManager() -{ - delete t1_; - delete t2_; -} +{} int TransManager::SetPrimary(string const & language) @@ -225,7 +228,7 @@ bool TransManager::setCharset(string const & str) void TransManager::EnablePrimary() { if (t1_->IsDefined()) - active_ = t1_; + active_ = t1_.get(); lyxerr[Debug::KBMAP] << "Enabling primary keymap" << endl; } @@ -234,7 +237,7 @@ void TransManager::EnablePrimary() void TransManager::EnableSecondary() { if (t2_->IsDefined()) - active_ = t2_; + active_ = t2_.get(); lyxerr[Debug::KBMAP] << "Enabling secondary keymap" << endl; } @@ -262,11 +265,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 +284,13 @@ void TransManager::insert(string const & str, LyXText * text) // Could not find an encoding InsetLatexAccent ins(str); if (ins.canDisplay()) { - text->insertInset( - new InsetLatexAccent(ins)); + text->bv()->cursor().insert(new InsetLatexAccent(ins)); } else { insertVerbatim(str, text); } return; } - string tmp; - tmp += static_cast(enc.second); + string const tmp(1, static_cast(enc.second)); insertVerbatim(tmp, text); }