| // Copyright (c) 2011 The Chromium Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #ifndef CHROME_BROWSER_SPELLCHECK_HOST_H_ |
| #define CHROME_BROWSER_SPELLCHECK_HOST_H_ |
| #pragma once |
| |
| #include <string> |
| #include <vector> |
| |
| #include "base/memory/ref_counted.h" |
| #include "base/platform_file.h" |
| #include "content/browser/browser_thread.h" |
| |
| class Profile; |
| class SpellCheckHostObserver; |
| |
| namespace net { |
| class URLRequestContextGetter; |
| } |
| |
| // An abstract interface that provides operations that controls the spellchecker |
| // attached to the browser. This class provides the operations listed below: |
| // * Adding a word to the user dictionary; |
| // * Retrieving the dictionary file (if it has one); |
| // * Retrieving the list of words in the user dictionary; |
| // * Retrieving the language used by the spellchecker. |
| // * Listing available languages for a Profile object; |
| // * Accepting an observer to reacting the state change of the object. |
| // You can also remove the observer from the SpellCheckHost object. |
| // The object should implement SpellCheckHostObserver interface. |
| // |
| // The following snippet describes how to use this class, |
| // std::vector<std::string> languages; |
| // SpellCheckHost::GetSpellCheckLanguages(profile_, &languages); |
| // spellcheck_host_ = SpellCheckHost::Create( |
| // observer, languages[0], req_getter); |
| // |
| // The class is intended to be owned by ProfileImpl so users should |
| // retrieve the instance via Profile::GetSpellCheckHost(). |
| // Users should not hold the reference over the function scope because |
| // the instance can be invalidated during the browser's lifecycle. |
| class SpellCheckHost |
| : public base::RefCountedThreadSafe<SpellCheckHost, |
| BrowserThread::DeleteOnFileThread> { |
| public: |
| virtual ~SpellCheckHost() {} |
| |
| // Creates the instance of SpellCheckHost implementation object. |
| static scoped_refptr<SpellCheckHost> Create( |
| SpellCheckHostObserver* observer, |
| const std::string& language, |
| net::URLRequestContextGetter* request_context_getter); |
| |
| // Clears an observer which is set on creation. |
| // Used to prevent calling back to a deleted object. |
| virtual void UnsetObserver() = 0; |
| |
| // Adds the given word to the custom words list and inform renderer of the |
| // update. |
| virtual void AddWord(const std::string& word) = 0; |
| |
| virtual const base::PlatformFile& GetDictionaryFile() const = 0; |
| |
| virtual const std::vector<std::string>& GetCustomWords() const = 0; |
| |
| virtual const std::string& GetLastAddedFile() const = 0; |
| |
| virtual const std::string& GetLanguage() const = 0; |
| |
| virtual bool IsUsingPlatformChecker() const = 0; |
| |
| // This function computes a vector of strings which are to be displayed in |
| // the context menu over a text area for changing spell check languages. It |
| // returns the index of the current spell check language in the vector. |
| // TODO(port): this should take a vector of string16, but the implementation |
| // has some dependencies in l10n util that need porting first. |
| static int GetSpellCheckLanguages(Profile* profile, |
| std::vector<std::string>* languages); |
| }; |
| |
| #endif // CHROME_BROWSER_SPELLCHECK_HOST_H_ |