parent
2ea4fa0ce6
commit
defdf8e6ae
|
@ -1,6 +1,5 @@
|
||||||
using Gdk;
|
using Gdk;
|
||||||
using Gee;
|
using Gee;
|
||||||
using Gspell;
|
|
||||||
|
|
||||||
using Dino.Entities;
|
using Dino.Entities;
|
||||||
|
|
||||||
|
@ -9,12 +8,14 @@ namespace Dino.Ui {
|
||||||
public class SpellChecker {
|
public class SpellChecker {
|
||||||
|
|
||||||
private Conversation? conversation;
|
private Conversation? conversation;
|
||||||
private TextView text_view;
|
private Gtk.TextView text_input;
|
||||||
private TextBuffer text_buffer;
|
|
||||||
|
|
||||||
public SpellChecker(Gtk.TextView text_input) {
|
public SpellChecker(Gtk.TextView text_input) {
|
||||||
this.text_view = TextView.get_from_gtk_text_view(text_input);
|
this.text_input = text_input;
|
||||||
this.text_buffer = TextBuffer.get_from_gtk_text_buffer(text_view.view.buffer);
|
|
||||||
|
// We can't keep a reference to GspellTextView/Buffer around, otherwise they'd get freed twice
|
||||||
|
Gspell.TextView text_view = Gspell.TextView.get_from_gtk_text_view(text_input);
|
||||||
|
Gspell.TextBuffer text_buffer = Gspell.TextBuffer.get_from_gtk_text_buffer(text_view.view.buffer);
|
||||||
|
|
||||||
text_view.basic_setup();
|
text_view.basic_setup();
|
||||||
text_buffer.spell_checker.notify["language"].connect(lang_changed);
|
text_buffer.spell_checker.notify["language"].connect(lang_changed);
|
||||||
|
@ -32,11 +33,14 @@ public class SpellChecker {
|
||||||
public void initialize_for_conversation(Conversation conversation) {
|
public void initialize_for_conversation(Conversation conversation) {
|
||||||
this.conversation = conversation;
|
this.conversation = conversation;
|
||||||
|
|
||||||
|
Gspell.TextView text_view = Gspell.TextView.get_from_gtk_text_view(text_input);
|
||||||
|
Gspell.TextBuffer text_buffer = Gspell.TextBuffer.get_from_gtk_text_buffer(text_view.view.buffer);
|
||||||
|
|
||||||
if (!Dino.Application.get_default().settings.check_spelling) {
|
if (!Dino.Application.get_default().settings.check_spelling) {
|
||||||
text_buffer.set_spell_checker(null);
|
text_buffer.set_spell_checker(null);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (text_buffer.spell_checker == null) text_buffer.spell_checker = new Checker(null);
|
if (text_buffer.spell_checker == null) text_buffer.spell_checker = new Gspell.Checker(null);
|
||||||
|
|
||||||
// Set the conversation language (from cache or db)
|
// Set the conversation language (from cache or db)
|
||||||
text_buffer.spell_checker.notify["language"].disconnect(lang_changed);
|
text_buffer.spell_checker.notify["language"].disconnect(lang_changed);
|
||||||
|
@ -48,7 +52,7 @@ public class SpellChecker {
|
||||||
.single().row();
|
.single().row();
|
||||||
if (row_option.is_present()) {
|
if (row_option.is_present()) {
|
||||||
string lang_code = row_option.inner[db.conversation_settings.value];
|
string lang_code = row_option.inner[db.conversation_settings.value];
|
||||||
Language? lang = Language.lookup(lang_code);
|
Gspell.Language? lang = Gspell.Language.lookup(lang_code);
|
||||||
text_buffer.spell_checker.language = lang;
|
text_buffer.spell_checker.language = lang;
|
||||||
} else {
|
} else {
|
||||||
text_buffer.spell_checker.language = null;
|
text_buffer.spell_checker.language = null;
|
||||||
|
@ -60,8 +64,11 @@ public class SpellChecker {
|
||||||
private void lang_changed() {
|
private void lang_changed() {
|
||||||
var db = Dino.Application.get_default().db;
|
var db = Dino.Application.get_default().db;
|
||||||
|
|
||||||
Checker spell_checker = text_buffer.spell_checker;
|
Gspell.TextView text_view = Gspell.TextView.get_from_gtk_text_view(text_input);
|
||||||
|
Gspell.TextBuffer text_buffer = Gspell.TextBuffer.get_from_gtk_text_buffer(text_view.view.buffer);
|
||||||
|
Gspell.Checker spell_checker = text_buffer.spell_checker;
|
||||||
if (spell_checker.language.get_code() == null) return;
|
if (spell_checker.language.get_code() == null) return;
|
||||||
|
|
||||||
db.conversation_settings.upsert()
|
db.conversation_settings.upsert()
|
||||||
.value(db.conversation_settings.conversation_id, conversation.id, true)
|
.value(db.conversation_settings.conversation_id, conversation.id, true)
|
||||||
.value(db.conversation_settings.key, "lang", true)
|
.value(db.conversation_settings.key, "lang", true)
|
||||||
|
|
Loading…
Reference in a new issue