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 81 82 83 84
|
/* vim: set ts=2 sw=2 sts=2 tw=80: */
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
#include "RemoteSpellCheckEngineParent.h"
#include "mozilla/mozSpellChecker.h"
#include "nsServiceManagerUtils.h"
namespace mozilla {
RemoteSpellcheckEngineParent::RemoteSpellcheckEngineParent() {
mSpellChecker = mozSpellChecker::Create();
}
RemoteSpellcheckEngineParent::~RemoteSpellcheckEngineParent() {}
mozilla::ipc::IPCResult RemoteSpellcheckEngineParent::RecvSetDictionary(
const nsACString& aDictionary, bool* success) {
nsresult rv = mSpellChecker->SetCurrentDictionary(aDictionary);
*success = NS_SUCCEEDED(rv);
return IPC_OK();
}
mozilla::ipc::IPCResult RemoteSpellcheckEngineParent::RecvSetDictionaries(
const nsTArray<nsCString>& aDictionaries,
SetDictionariesResolver&& aResolve) {
mSpellChecker->SetCurrentDictionaries(aDictionaries)
->Then(
GetMainThreadSerialEventTarget(), __func__,
[aResolve]() { aResolve(true); }, [aResolve]() { aResolve(false); });
return IPC_OK();
}
mozilla::ipc::IPCResult RemoteSpellcheckEngineParent::RecvSetDictionaryFromList(
nsTArray<nsCString>&& aList, SetDictionaryFromListResolver&& aResolve) {
for (auto& dictionary : aList) {
nsresult rv = mSpellChecker->SetCurrentDictionary(dictionary);
if (NS_SUCCEEDED(rv)) {
aResolve(std::tuple<const bool&, const nsACString&>(true, dictionary));
return IPC_OK();
}
}
aResolve(std::tuple<const bool&, const nsACString&>(false, ""_ns));
return IPC_OK();
}
mozilla::ipc::IPCResult RemoteSpellcheckEngineParent::RecvCheckAsync(
nsTArray<nsString>&& aWords, CheckAsyncResolver&& aResolve) {
nsTArray<bool> misspells;
misspells.SetCapacity(aWords.Length());
for (auto& word : aWords) {
bool misspelled;
nsresult rv = mSpellChecker->CheckWord(word, &misspelled, nullptr);
// If CheckWord failed, we can't tell whether the word is correctly spelled
if (NS_FAILED(rv)) {
misspelled = false;
}
misspells.AppendElement(misspelled);
}
aResolve(std::move(misspells));
return IPC_OK();
}
mozilla::ipc::IPCResult RemoteSpellcheckEngineParent::RecvSuggest(
const nsAString& aWord, uint32_t aCount, SuggestResolver&& aResolve) {
nsTArray<nsString> suggestions;
mSpellChecker->Suggest(aWord, aCount)
->Then(
GetMainThreadSerialEventTarget(), __func__,
[aResolve](CopyableTArray<nsString> aSuggestions) {
aResolve(std::move(aSuggestions));
},
[aResolve](nsresult aError) {
// No suggestions due to error
nsTArray<nsString> suggestions;
aResolve(std::move(suggestions));
});
return IPC_OK();
}
void RemoteSpellcheckEngineParent::ActorDestroy(ActorDestroyReason aWhy) {}
} // namespace mozilla
|