diff options
author | darin@chromium.org <darin@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-08-10 05:46:45 +0000 |
---|---|---|
committer | darin@chromium.org <darin@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-08-10 05:46:45 +0000 |
commit | dd7daa80d25deb78ab365e28df4d93437357793b (patch) | |
tree | fb4dd2331820f5e32ddeb7e2bfb731f0604fbc0d /webkit/glue/webtextinput_impl.cc | |
parent | 64c40aa34646a198a04029ee6b78dd9559595dc5 (diff) | |
download | chromium_src-dd7daa80d25deb78ab365e28df4d93437357793b.zip chromium_src-dd7daa80d25deb78ab365e28df4d93437357793b.tar.gz chromium_src-dd7daa80d25deb78ab365e28df4d93437357793b.tar.bz2 |
Switch to WebFrame from the WebKit API.
I tried to avoid unnecessary changes in this CL to help make it easier to
review.
As part of this CL, glue/webtextinput* are folded into WebFrame / WebFrameImpl.
R=dglazkov
BUG=10034
TEST=none
Review URL: http://codereview.chromium.org/164225
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@22896 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'webkit/glue/webtextinput_impl.cc')
-rw-r--r-- | webkit/glue/webtextinput_impl.cc | 157 |
1 files changed, 0 insertions, 157 deletions
diff --git a/webkit/glue/webtextinput_impl.cc b/webkit/glue/webtextinput_impl.cc deleted file mode 100644 index 84dcb9b..0000000 --- a/webkit/glue/webtextinput_impl.cc +++ /dev/null @@ -1,157 +0,0 @@ -// Copyright (c) 2006-2008 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. - -#include <ctype.h> -#include "config.h" - -#include "base/compiler_specific.h" - -MSVC_PUSH_WARNING_LEVEL(0); -#include "Frame.h" -#include "Editor.h" -MSVC_POP_WARNING(); - -#undef LOG - -#include "base/string16.h" -#include "base/string_util.h" -#include "webkit/glue/glue_util.h" -#include "webkit/glue/webframe_impl.h" -#include "webkit/glue/webtextinput_impl.h" - -WebTextInputImpl::WebTextInputImpl(WebFrameImpl* web_frame_impl) - : WebTextInput(), - web_frame_impl_(web_frame_impl) { -} - -WebTextInputImpl::~WebTextInputImpl() { -} - -WebCore::Frame* WebTextInputImpl::GetFrame() { - return web_frame_impl_->frame(); -} - -WebCore::Editor* WebTextInputImpl::GetEditor() { - return web_frame_impl_->frame()->editor(); -} - -void WebTextInputImpl::InsertText(const string16& text) { - WebCore::String str = webkit_glue::String16ToString(text); - GetEditor()->insertText(str, NULL); -} - -void WebTextInputImpl::DoCommand(const string16& com) { - if (com.length() <= 2) - return; - - // Since we don't have NSControl, we will convert the format of command - // string and call the function on Editor directly. - string16 command = com; - - // Make sure the first letter is upper case. - command.replace(0, 1, 1, toupper(command.at(0))); - - // Remove the trailing ':' if existing. - if (command.at(command.length() - 1) == ':') - command.erase(command.length() - 1, 1); - - // Specially handling commands that Editor::execCommand does not directly - // support. - if (EqualsASCII(command, "DeleteToEndOfParagraph")) { - DeleteToEndOfParagraph(); - } else if(EqualsASCII(command, "Indent")) { - GetEditor()->indent(); - } else if(EqualsASCII(command, "Outdent")) { - GetEditor()->outdent(); - } else if(EqualsASCII(command, "DeleteBackward")) { - WebCore::AtomicString editor_command("BackwardDelete"); - GetEditor()->command(editor_command).execute(); - } else if(EqualsASCII(command, "DeleteForward")) { - WebCore::AtomicString editor_command("ForwardDelete"); - GetEditor()->command(editor_command).execute(); - } else { - WebCore::AtomicString editor_command(command.c_str()); - GetEditor()->command(editor_command).execute(); - } - - return; -} - -void WebTextInputImpl::SetMarkedText(const string16& text, - int32_t location, - int32_t length) { - WebCore::Editor* editor = GetEditor(); - WebCore::String str = webkit_glue::String16ToString(text); - - editor->confirmComposition(str); - - WTF::Vector<WebCore::CompositionUnderline> decorations; - - editor->setComposition(str, decorations, location, length); -} - -void WebTextInputImpl::UnMarkText() { - GetEditor()->confirmCompositionWithoutDisturbingSelection();; -} - -bool WebTextInputImpl::HasMarkedText() { - return GetEditor()->hasComposition(); -} - -void WebTextInputImpl::ConversationIdentifier() { -} - -void WebTextInputImpl::SubstringFromRange(int32_t location, int32_t length) { -} - -void WebTextInputImpl::AttributedSubstringFromRange(int32_t location, - int32_t length) { -} - -void WebTextInputImpl::MarkedRange(std::string* range_str) { - RefPtr<WebCore::Range> range = GetEditor()->compositionRange(); - - // Range::toString() returns a string different from what test expects. - // So we need to construct the string ourselves. - SStringPrintf(range_str, "%d,%d", range->startPosition().deprecatedEditingOffset(), - range->endPosition().deprecatedEditingOffset()); -} - -void WebTextInputImpl::SelectedRange(std::string* range_str) { - WTF::RefPtr<WebCore::Range> range - = GetFrame()->selection()->toNormalizedRange(); - - // Range::toString() returns a string different from what test expects. - // So we need to construct the string ourselves. - SStringPrintf(range_str, "%d,%d", range.get()->startPosition().deprecatedEditingOffset(), - range.get()->endPosition().deprecatedEditingOffset()); -} - -void WebTextInputImpl::FirstRectForCharacterRange(int32_t location, - int32_t length) { -} - -void WebTextInputImpl::CharacterIndexForPoint(double x, double y) { -} - -void WebTextInputImpl::ValidAttributesForMarkedText(std::string* attributes) { - // We simply return a string with relevant keywords. - attributes->assign("NSUnderline,NSUnderlineColor,NSMarkedClauseSegment,NSTextInputReplacementRangeAttributeName"); -} - -void WebTextInputImpl::MakeAttributedString(const std::string& str) { -} - -void WebTextInputImpl::DeleteToEndOfParagraph() { - WebCore::Editor* editor = GetEditor(); - if (!editor->deleteWithDirection(WebCore::SelectionController::FORWARD, - WebCore::ParagraphBoundary, - true, - false)) { - editor->deleteWithDirection(WebCore::SelectionController::FORWARD, - WebCore::CharacterGranularity, - true, - false); - } -} |