Skip to content

Commit

Permalink
feat(api): highlight_candidate*, change_page
Browse files Browse the repository at this point in the history
add function Context::Highlight

Merges #620

Squashed commit of the following:

commit bff5a89a8abb31c0ca612e42fe704cb8b522e2df
Author: 居戎氏 <[email protected]>
Date:   Fri Feb 9 11:01:36 2024 +0800

    rename the new function Context::Highlight

    do not re-use it in Context::Select

commit fbc709e
Author: 居戎氏 <[email protected]>
Date:   Thu Feb 8 23:03:43 2024 +0800

    re-order API functions

commit 0de4da0
Author: 居戎氏 <[email protected]>
Date:   Thu Feb 8 22:20:35 2024 +0800

    fix: missing brackets in if-statement

commit 5c1502e
Author: LEO Yoon-Tsaw <[email protected]>
Date:   Tue Feb 21 09:49:34 2023 -0500

    Fix RECOMMENDED_MACOSX_DEPLOYMENT_TARGET error

commit ecd3649
Author: LEO Yoon-Tsaw <[email protected]>
Date:   Mon Feb 20 16:42:45 2023 -0500

    Update context.cc

commit 9aa83e6
Author: LEO Yoon-Tsaw <[email protected]>
Date:   Sun Feb 19 23:56:17 2023 -0500

    Add new APIs, peek selection and change page

    Context:Peek
  • Loading branch information
LEOYoon-Tsaw authored and lotem committed Feb 9, 2024
1 parent 0e946e7 commit 142902d
Show file tree
Hide file tree
Showing 4 changed files with 64 additions and 0 deletions.
21 changes: 21 additions & 0 deletions src/rime/context.cc
Original file line number Diff line number Diff line change
Expand Up @@ -121,6 +121,27 @@ bool Context::Select(size_t index) {
return false;
}

bool Context::Highlight(size_t index) {
if (composition_.empty() || !composition_.back().menu)
return false;
Segment& seg(composition_.back());
size_t new_index = index;
size_t candidate_count = seg.menu->Prepare(index + 1);
if (index >= candidate_count) {
DLOG(INFO) << "selection index exceeds candidate pool, fallback to last";
new_index = candidate_count - 1;
}
size_t previous_index = seg.selected_index;
if (previous_index == new_index) {
DLOG(INFO) << "selection has not changed, currently at " << new_index;
return false;
}
seg.selected_index = new_index;
update_notifier_(this);
DLOG(INFO) << "selection changed from: " << previous_index << " to: " << new_index;
return true;
}

bool Context::DeleteCandidate(
function<an<Candidate>(Segment& seg)> get_candidate) {
if (composition_.empty())
Expand Down
2 changes: 2 additions & 0 deletions src/rime/context.h
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,8 @@ class RIME_API Context {

// return false if there is no candidate at index
bool Select(size_t index);
// return false if the selected index has not changed
bool Highlight(size_t index);
bool DeleteCandidate(size_t index);
// return false if there's no candidate for current segment
bool ConfirmCurrentSelection();
Expand Down
34 changes: 34 additions & 0 deletions src/rime_api.cc
Original file line number Diff line number Diff line change
Expand Up @@ -1066,6 +1066,37 @@ static bool do_with_candidate_on_current_page(
return (ctx->*verb)(page_start + index);
}

Bool RimeChangePage(RimeSessionId session_id, Bool backward) {
an<Session> session(Service::instance().GetSession(session_id));
if (!session)
return False;
Context *ctx = session->context();
if (!ctx || !ctx->HasMenu())
return False;
Schema *schema = session->schema();
if (!schema)
return False;
size_t page_size = (size_t)schema->page_size();
auto& seg(ctx->composition().back());
size_t current_index = seg.selected_index;
size_t index =
backward ? (current_index <= page_size ? 0 : current_index - page_size)
: (current_index + page_size);
DLOG(INFO) << "current selection: " << current_index
<< ", flipping " << (backward ? "backward" : "forward")
<< ", new selection " << index;
seg.tags.insert("paging");
return ctx->Highlight(index);
}

Bool RimeHighlightCandidate(RimeSessionId session_id, size_t index) {
return do_with_candidate(session_id, index, &Context::Highlight);
}

Bool RimeHighlightCandidateOnCurrentPage(RimeSessionId session_id, size_t index) {
return do_with_candidate_on_current_page(session_id, index, &Context::Highlight);
}

RIME_API Bool RimeSelectCandidate(RimeSessionId session_id, size_t index) {
return do_with_candidate(session_id, index, &Context::Select);
}
Expand Down Expand Up @@ -1231,6 +1262,9 @@ RIME_API RimeApi* rime_get_api() {
s_api.get_prebuilt_data_dir_s = &RimeGetPrebuiltDataDirSecure;
s_api.get_staging_dir_s = &RimeGetStagingDirSecure;
s_api.get_sync_dir_s = &RimeGetSyncDirSecure;
s_api.highlight_candidate = &RimeHighlightCandidate;
s_api.highlight_candidate_on_current_page = &RimeHighlightCandidateOnCurrentPage;
s_api.change_page = &RimeChangePage;
}
return &s_api;
}
7 changes: 7 additions & 0 deletions src/rime_api.h
Original file line number Diff line number Diff line change
Expand Up @@ -664,6 +664,13 @@ typedef struct rime_api_t {
void (*get_prebuilt_data_dir_s)(char* dir, size_t buffer_size);
void (*get_staging_dir_s)(char* dir, size_t buffer_size);
void (*get_sync_dir_s)(char* dir, size_t buffer_size);

//! highlight a selection without committing
Bool (*highlight_candidate)(RimeSessionId session_id, size_t index);
//! highlight a selection without committing
Bool (*highlight_candidate_on_current_page)(RimeSessionId session_id, size_t index);

Bool (*change_page)(RimeSessionId session_id, Bool backward);
} RimeApi;

//! API entry
Expand Down

0 comments on commit 142902d

Please sign in to comment.