Skip to content

Commit

Permalink
Merge pull request #625 from chewing/feat-auto-snapshot
Browse files Browse the repository at this point in the history
feat(editor): Automatic snapshot selections when the curser is moved
  • Loading branch information
kanru authored Jul 20, 2024
2 parents 613f9ca + 045cb10 commit 705e585
Show file tree
Hide file tree
Showing 2 changed files with 102 additions and 81 deletions.
179 changes: 100 additions & 79 deletions src/editor/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -523,6 +523,12 @@ impl SharedState {
fn intervals(&self) -> impl Iterator<Item = Interval> {
self.conversion().into_iter()
}
fn snapshot(&mut self) {
for interval in self.intervals() {
self.com.select(interval);
}
self.nth_conversion = 0;
}
fn cursor(&self) -> usize {
self.com.cursor()
}
Expand Down Expand Up @@ -922,26 +928,31 @@ impl State for Entering {
}
}
Home => {
shared.snapshot();
shared.com.move_cursor_to_beginning();
self.spin_absorb()
}
Left if ev.modifiers.shift => {
if shared.com.is_beginning_of_buffer() {
return self.spin_ignore();
}
shared.snapshot();
self.start_highlighting(shared.cursor() - 1)
}
Right if ev.modifiers.shift => {
if shared.com.is_end_of_buffer() {
return self.spin_ignore();
}
shared.snapshot();
self.start_highlighting(shared.cursor() + 1)
}
Left => {
shared.snapshot();
shared.com.move_cursor_left();
self.spin_absorb()
}
Right => {
shared.snapshot();
shared.com.move_cursor_right();
self.spin_absorb()
}
Expand All @@ -961,6 +972,7 @@ impl State for Entering {
self.start_selecting(shared)
}
End | PageUp | PageDown => {
shared.snapshot();
shared.com.move_cursor_to_end();
self.spin_absorb()
}
Expand All @@ -986,111 +998,120 @@ impl State for Entering {
self.spin_absorb()
}
}
_ => match shared.options.language_mode {
LanguageMode::Chinese if ev.code == Grave && ev.modifiers.is_none() => {
self.start_symbol_input(shared)
}
LanguageMode::Chinese if ev.code == Space => match shared.options.character_form {
CharacterForm::Halfwidth => {
if shared.com.is_empty() {
shared.commit_buffer.clear();
shared.commit_buffer.push(ev.unicode);
self.spin_commit()
} else {
shared.com.insert(Symbol::from(ev.unicode));
self.spin_absorb()
}
}
CharacterForm::Fullwidth => {
let char_ = full_width_symbol_input(ev.unicode).unwrap();
if shared.com.is_empty() {
shared.commit_buffer.clear();
shared.commit_buffer.push(char_);
self.spin_commit()
} else {
shared.com.insert(Symbol::from(char_));
self.spin_absorb()
}
}
},
LanguageMode::Chinese if shared.options.easy_symbol_input => {
// Priortize symbol input
if let Some(expended) = shared.abbr.find_abbrev(ev.unicode) {
expended
.chars()
.for_each(|ch| shared.com.insert(Symbol::from(ch)));
return self.spin_absorb();
}
if let Some(symbol) = special_symbol_input(ev.unicode) {
shared.com.insert(Symbol::from(symbol));
return self.spin_absorb();
}
if ev.modifiers.is_none() && KeyBehavior::Absorb == shared.syl.key_press(ev) {
return self.start_enter_syllable();
}
self.spin_bell()
_ => {
if shared.nth_conversion != 0 {
shared.snapshot();
}
LanguageMode::Chinese => {
if ev.modifiers.is_none() && KeyBehavior::Absorb == shared.syl.key_press(ev) {
return self.start_enter_syllable();
match shared.options.language_mode {
LanguageMode::Chinese if ev.code == Grave && ev.modifiers.is_none() => {
self.start_symbol_input(shared)
}
if let Some(symbol) = special_symbol_input(ev.unicode) {
shared.com.insert(Symbol::from(symbol));
return self.spin_absorb();
}
if ev.is_printable() {
LanguageMode::Chinese if ev.code == Space => {
match shared.options.character_form {
CharacterForm::Halfwidth => {
if shared.com.is_empty() {
// FIXME we should ignore these keys if pre-edit is empty
shared.commit_buffer.clear();
shared.commit_buffer.push(ev.unicode);
return self.spin_commit();
self.spin_commit()
} else {
shared.com.insert(Symbol::from(ev.unicode));
return self.spin_absorb();
self.spin_absorb()
}
}
CharacterForm::Fullwidth => {
let char_ = full_width_symbol_input(ev.unicode).unwrap();
if shared.com.is_empty() {
shared.commit_buffer.clear();
shared.commit_buffer.push(char_);
return self.spin_commit();
self.spin_commit()
} else {
shared.com.insert(Symbol::from(char_));
return self.spin_absorb();
self.spin_absorb()
}
}
}
}
self.spin_bell()
}
LanguageMode::English => match shared.options.character_form {
CharacterForm::Halfwidth => {
if shared.com.is_empty() {
// FIXME we should ignore these keys if pre-edit is empty
shared.commit_buffer.clear();
shared.commit_buffer.push(ev.unicode);
self.spin_commit()
} else {
shared.com.insert(Symbol::from(ev.unicode));
self.spin_absorb()
LanguageMode::Chinese if shared.options.easy_symbol_input => {
// Priortize symbol input
if let Some(expended) = shared.abbr.find_abbrev(ev.unicode) {
expended
.chars()
.for_each(|ch| shared.com.insert(Symbol::from(ch)));
return self.spin_absorb();
}
if let Some(symbol) = special_symbol_input(ev.unicode) {
shared.com.insert(Symbol::from(symbol));
return self.spin_absorb();
}
if ev.modifiers.is_none() && KeyBehavior::Absorb == shared.syl.key_press(ev)
{
return self.start_enter_syllable();
}
self.spin_bell()
}
CharacterForm::Fullwidth => {
let char_ = full_width_symbol_input(ev.unicode).unwrap();
if shared.com.is_empty() {
shared.commit_buffer.clear();
shared.commit_buffer.push(char_);
self.spin_commit()
} else {
shared.com.insert(Symbol::from(char_));
self.spin_absorb()
LanguageMode::Chinese => {
if ev.modifiers.is_none() && KeyBehavior::Absorb == shared.syl.key_press(ev)
{
return self.start_enter_syllable();
}
if let Some(symbol) = special_symbol_input(ev.unicode) {
shared.com.insert(Symbol::from(symbol));
return self.spin_absorb();
}
if ev.is_printable() {
match shared.options.character_form {
CharacterForm::Halfwidth => {
if shared.com.is_empty() {
// FIXME we should ignore these keys if pre-edit is empty
shared.commit_buffer.clear();
shared.commit_buffer.push(ev.unicode);
return self.spin_commit();
} else {
shared.com.insert(Symbol::from(ev.unicode));
return self.spin_absorb();
}
}
CharacterForm::Fullwidth => {
let char_ = full_width_symbol_input(ev.unicode).unwrap();
if shared.com.is_empty() {
shared.commit_buffer.clear();
shared.commit_buffer.push(char_);
return self.spin_commit();
} else {
shared.com.insert(Symbol::from(char_));
return self.spin_absorb();
}
}
}
}
self.spin_bell()
}
},
},
LanguageMode::English => match shared.options.character_form {
CharacterForm::Halfwidth => {
if shared.com.is_empty() {
// FIXME we should ignore these keys if pre-edit is empty
shared.commit_buffer.clear();
shared.commit_buffer.push(ev.unicode);
self.spin_commit()
} else {
shared.com.insert(Symbol::from(ev.unicode));
self.spin_absorb()
}
}
CharacterForm::Fullwidth => {
let char_ = full_width_symbol_input(ev.unicode).unwrap();
if shared.com.is_empty() {
shared.commit_buffer.clear();
shared.commit_buffer.push(char_);
self.spin_commit()
} else {
shared.com.insert(Symbol::from(char_));
self.spin_absorb()
}
}
},
}
}
}
}

Expand Down
4 changes: 2 additions & 2 deletions tests/test-bopomofo.c
Original file line number Diff line number Diff line change
Expand Up @@ -583,7 +583,7 @@ void test_Del_word()
chewing_set_maxChiSymbolLen(ctx, 16);

type_keystroke_by_string(ctx, "hk4u g4<L><L><DC><E>");
ok_commit_buffer(ctx, "\xE6\xB8\xAC\xE8\xA9\xA6" /* 測試 */ );
ok_commit_buffer(ctx, "冊市" );

chewing_delete(ctx);
}
Expand Down Expand Up @@ -654,7 +654,7 @@ void test_Backspace_word()
chewing_set_maxChiSymbolLen(ctx, 16);

type_keystroke_by_string(ctx, "hk4u g4<L><B><E>");
ok_commit_buffer(ctx, "\xE6\xB8\xAC\xE8\xA9\xA6" /* 測試 */ );
ok_commit_buffer(ctx, "冊市" );

chewing_delete(ctx);
}
Expand Down

0 comments on commit 705e585

Please sign in to comment.