1 /* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
2 /* This Source Code Form is subject to the terms of the Mozilla Public
3 * License, v. 2.0. If a copy of the MPL was not distributed with this
4 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
6 #include
"nsISupports.idl"
9 interface nsIEditorSpellCheckCallback
;
11 [scriptable
, uuid(a171c25f
-e4a8
-4d08
-adef
-b797e6377bdc
)]
12 interface nsIEditorSpellCheck
: nsISupports
16 * Returns true if we can enable spellchecking. If there are no available
17 * dictionaries, this will return false.
19 boolean canSpellCheck
();
22 * Turns on the spell checker for the given editor. enableSelectionChecking
23 * set means that we only want to check the current selection in the editor,
24 * (this controls the behavior of GetNextMisspelledWord). For spellchecking
25 * clients with no modal UI (such as inline spellcheckers), this flag doesn't
26 * matter. Initialization is asynchronous and is not complete until the given
29 void InitSpellChecker
(in nsIEditor editor
, in boolean enableSelectionChecking
,
30 [optional] in nsIEditorSpellCheckCallback
callback);
33 * When interactively spell checking the document, this will return the
34 * value of the next word that is misspelled. This also computes the
35 * suggestions which you can get by calling GetSuggestedWord.
37 * @see mozSpellChecker::GetNextMisspelledWord
40 AString GetNextMisspelledWord
();
43 * Used to get suggestions for the last word that was checked and found to
44 * be misspelled. The first call will give you the first (best) suggestion.
45 * Subsequent calls will iterate through all the suggestions, allowing you
46 * to build a list. When there are no more suggestions, an empty string
47 * (not a null pointer) will be returned.
49 * @see mozSpellChecker::GetSuggestedWord
51 AString GetSuggestedWord
();
54 * Check a given word. In spite of the name, this function checks the word
55 * you give it, returning true if the word is misspelled. If the word is
56 * misspelled, it will compute the suggestions which you can get from
59 * @see mozSpellChecker::CheckCurrentWord
61 boolean CheckCurrentWord
(in AString suggestedWord
);
64 * Check a given word then returns suggestion words via Promise if a given
65 * word is misspelled. If not misspelled, returns empty string array.
68 Promise suggest
(in AString aCheckingWorkd
, in unsigned long aMaxCount
);
71 * Use when modally checking the document to replace a word.
73 * @see mozSpellChecker::CheckCurrentWord
76 void ReplaceWord
(in AString misspelledWord
, in AString replaceWord
, in boolean allOccurrences
);
79 * @see mozSpellChecker::IgnoreAll
81 void IgnoreWordAllOccurrences
(in AString word
);
84 * Adds a word to the current personal dictionary.
86 * @see mozSpellChecker::AddWordToDictionary
88 void AddWordToDictionary
(in AString word
);
91 * Removes a word from the current personal dictionary.
93 * @see mozSpellChecker::RemoveWordFromPersonalDictionary
95 void RemoveWordFromDictionary
(in AString word
);
98 * Retrieves a list of the currently available dictionaries. The strings will
99 * typically be language IDs, like "en-US".
101 * @see mozISpellCheckingEngine::GetDictionaryList
103 Array
<ACString
> GetDictionaryList
();
106 * @see mozSpellChecker::GetCurrentDictionaries
108 Array
<ACString
> getCurrentDictionaries
();
111 * @see mozSpellChecker::SetCurrentDictionaries
114 Promise setCurrentDictionaries
(in Array
<ACString
> dictionaries
);
117 * Call this to free up the spell checking object. It will also save the
118 * current selected language as the default for future use.
120 * If you have called CanSpellCheck but not InitSpellChecker, you can still
121 * call this function to clear the cached spell check object, and no
122 * preference saving will happen.
124 void UninitSpellChecker
();
126 const unsigned long FILTERTYPE_NORMAL
= 1;
127 const unsigned long FILTERTYPE_MAIL
= 2;
130 * Used to filter the content (for example, to skip blockquotes in email from
131 * spellchecking. Call this before calling InitSpellChecker; calling it
132 * after initialization will have no effect.
134 void setFilterType
(in unsigned long filterType
);
137 * Update the dictionary in use to be sure it corresponds to what the editor
138 * needs. The update is asynchronous and is not complete until the given
139 * callback is called.
141 void UpdateCurrentDictionary
([optional] in nsIEditorSpellCheckCallback
callback);
145 [scriptable
, function
, uuid(5f0a4bab
-8538-4074-89d3
-2f0e866a1c0b
)]
146 interface nsIEditorSpellCheckCallback
: nsISupports
148 void editorSpellCheckDone
();