// Copyright 2013 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 WIN8_METRO_DRIVER_IME_TEXT_SERVICE_H_
#define WIN8_METRO_DRIVER_IME_TEXT_SERVICE_H_
#include <Windows.h>
#include <vector>
#include "base/basictypes.h"
#include "base/memory/scoped_ptr.h"
namespace metro_viewer {
struct CharacterBounds;
}
namespace metro_driver {
class TextServiceDelegate;
// An interface to manage a virtual text store with which an IME communicates.
class TextService {
 public:
  virtual ~TextService() {}
  // Cancels on-going composition. Does nothing if there is no composition.
  virtual void CancelComposition() = 0;
  // Updates document type with |input_scopes| and caret/composition position
  // with |character_bounds|.  An empty |input_scopes| indicates that IMEs
  // should be disabled until non-empty |input_scopes| is specified.
  // Note: |input_scopes| is defined as std::vector<int32> here rather than
  // std::vector<InputScope> because the wire format of IPC message
  // MetroViewerHostMsg_ImeTextInputClientUpdated uses std::vector<int32> to
  // avoid dependency on <InputScope.h> header.
  virtual void OnDocumentChanged(
      const std::vector<int32>& input_scopes,
      const std::vector<metro_viewer::CharacterBounds>& character_bounds) = 0;
  // Must be called whenever the attached window gains keyboard focus.
  virtual void OnWindowActivated() = 0;
};
// Returns an instance of TextService that works together with
// |text_store_delegate| as if it was an text area owned by |window_handle|.
scoped_ptr<TextService>
CreateTextService(TextServiceDelegate* delegate, HWND window_handle);
}  // namespace metro_driver
#endif  // WIN8_METRO_DRIVER_IME_TEXT_SERVICE_H_