1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
|
#pragma once
#include "Base.hpp"
#include "cru/common/Event.hpp"
#include <memory>
#include <vector>
namespace cru::platform::gui {
struct CompositionClause {
int start;
int end;
bool target;
};
using CompositionClauses = std::vector<CompositionClause>;
struct CompositionText {
String text;
CompositionClauses clauses;
TextRange selection;
};
struct IInputMethodContext : virtual IPlatformResource {
// Return true if you should draw composition text manually. Return false if
// system will take care of that for you.
virtual bool ShouldManuallyDrawCompositionText() = 0;
virtual void EnableIME() = 0;
virtual void DisableIME() = 0;
virtual void CompleteComposition() = 0;
virtual void CancelComposition() = 0;
virtual CompositionText GetCompositionText() = 0;
// Set the candidate window lefttop. Relative to window lefttop. Use this
// method to prepare typing.
virtual void SetCandidateWindowPosition(const Point& point) = 0;
// Triggered when user starts composition.
virtual IEvent<std::nullptr_t>* CompositionStartEvent() = 0;
// Triggered when user stops composition.
virtual IEvent<std::nullptr_t>* CompositionEndEvent() = 0;
// Triggered every time composition text changes.
virtual IEvent<std::nullptr_t>* CompositionEvent() = 0;
virtual IEvent<StringView>* TextEvent() = 0;
};
} // namespace cru::platform::gui
// template <>
// struct fmt::formatter<cru::platform::gui::CompositionText, char16_t>
// : fmt::formatter<std::u16string_view, char16_t> {
// auto parse(fmt::basic_format_parse_context<char16_t>& ctx) {
// return fmt::formatter<std::u16string_view, char16_t>::parse(ctx);
// }
// template <typename FormatContext>
// auto format(const cru::platform::gui::CompositionText& ct,
// FormatContext& ctx) {
// auto output = ctx.out();
// output = format_to(output, u"text: {}\n", ct.text);
// output = format_to(output, u"clauses:\n");
// for (gsl::index i = 0; i < static_cast<gsl::index>(ct.clauses.size());
// i++) {
// const auto& clause = ct.clauses[i];
// output =
// format_to(output, u"\t{}. start: {} end: {}{}\n", i, clause.start,
// clause.end, clause.target ? u" target" : u"");
// }
// output = format_to(output, u"selection: position: {} count: {}",
// ct.selection.position, ct.selection.count);
// return output;
// }
// };
|