OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright (C) 2005, 2007, 2008 Apple Inc. All rights reserved. | 2 * Copyright (C) 2005, 2007, 2008 Apple Inc. All rights reserved. |
3 * Copyright (C) 2011 Google Inc. All rights reserved. | 3 * Copyright (C) 2011 Google Inc. All rights reserved. |
4 * | 4 * |
5 * Redistribution and use in source and binary forms, with or without | 5 * Redistribution and use in source and binary forms, with or without |
6 * modification, are permitted provided that the following conditions are | 6 * modification, are permitted provided that the following conditions are |
7 * met: | 7 * met: |
8 * | 8 * |
9 * * Redistributions of source code must retain the above copyright | 9 * * Redistributions of source code must retain the above copyright |
10 * notice, this list of conditions and the following disclaimer. | 10 * notice, this list of conditions and the following disclaimer. |
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
46 #include "core/html/HTMLElement.h" | 46 #include "core/html/HTMLElement.h" |
47 #include "core/layout/HitTestResult.h" | 47 #include "core/layout/HitTestResult.h" |
48 #include "core/layout/LayoutObject.h" | 48 #include "core/layout/LayoutObject.h" |
49 #include "core/style/ComputedStyle.h" | 49 #include "core/style/ComputedStyle.h" |
50 #include "platform/fonts/Font.h" | 50 #include "platform/fonts/Font.h" |
51 #include "platform/mac/ColorMac.h" | 51 #include "platform/mac/ColorMac.h" |
52 #include "public/platform/WebRect.h" | 52 #include "public/platform/WebRect.h" |
53 #include "public/web/WebHitTestResult.h" | 53 #include "public/web/WebHitTestResult.h" |
54 #include "public/web/WebRange.h" | 54 #include "public/web/WebRange.h" |
55 #include "public/web/WebView.h" | 55 #include "public/web/WebView.h" |
56 #include "public/web/WebWidget.h" | |
57 #include "web/WebFrameWidgetBase.h" | |
58 #include "web/WebFrameWidgetImpl.h" | |
56 #include "web/WebLocalFrameImpl.h" | 59 #include "web/WebLocalFrameImpl.h" |
57 #include "web/WebViewImpl.h" | 60 #include "web/WebViewImpl.h" |
58 | 61 |
59 using namespace blink; | 62 using namespace blink; |
60 | 63 |
61 static NSAttributedString* attributedSubstringFromRange(const EphemeralRange& ra nge) | 64 static NSAttributedString* attributedSubstringFromRange(const EphemeralRange& ra nge) |
62 { | 65 { |
63 NSMutableAttributedString* string = [[NSMutableAttributedString alloc] init] ; | 66 NSMutableAttributedString* string = [[NSMutableAttributedString alloc] init] ; |
64 NSMutableDictionary* attrs = [NSMutableDictionary dictionary]; | 67 NSMutableDictionary* attrs = [NSMutableDictionary dictionary]; |
65 size_t length = range.endPosition().computeOffsetInContainerNode() - range.s tartPosition().computeOffsetInContainerNode(); | 68 size_t length = range.endPosition().computeOffsetInContainerNode() - range.s tartPosition().computeOffsetInContainerNode(); |
(...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
129 if ([string length]) { | 132 if ([string length]) { |
130 NSDictionary* attributes = [string attributesAtIndex:0 effectiveRange:NU LL]; | 133 NSDictionary* attributes = [string attributesAtIndex:0 effectiveRange:NU LL]; |
131 if (NSFont* font = [attributes objectForKey:NSFontAttributeName]) | 134 if (NSFont* font = [attributes objectForKey:NSFontAttributeName]) |
132 stringPoint.move(0, ceil(-[font descender])); | 135 stringPoint.move(0, ceil(-[font descender])); |
133 } | 136 } |
134 return stringPoint; | 137 return stringPoint; |
135 } | 138 } |
136 | 139 |
137 namespace blink { | 140 namespace blink { |
138 | 141 |
139 NSAttributedString* WebSubstringUtil::attributedWordAtPoint(WebView* view, WebPo int point, WebPoint& baselinePoint) | 142 NSAttributedString* WebSubstringUtil::attributedWordAtPoint(WebView* view, WebWi dget* widget, WebPoint point, WebPoint& baselinePoint) |
140 { | 143 { |
141 HitTestResult result = static_cast<WebViewImpl*>(view)->coreHitTestResultAt( point); | 144 WebViewImpl* viewImpl = static_cast<WebViewImpl*>(view); |
145 | |
146 // Either this call is for a main frame's WebView or a local roots WebFrameW idgetImpl. | |
147 if (!viewImpl->mainFrameImpl() && !widget) | |
148 return nil; | |
149 | |
150 // Either we are in the main frame, where |widget| is a WebViewImpl equal to |view|, or, |widget| is a WebFrameWidget. | |
151 HitTestResult result = widget->isWebView() ? viewImpl->coreHitTestResultAt(p oint) : static_cast<WebFrameWidgetImpl*>(widget)->coreHitTestResultAt(point); | |
kenrb
2016/09/12 17:28:13
It looks like you dereference widget without first
EhsanK
2016/09/13 18:52:15
I believe neither |view| nor (specifically) |widge
| |
152 | |
142 if (!result.innerNode()) | 153 if (!result.innerNode()) |
143 return nil; | 154 return nil; |
144 LocalFrame* frame = result.innerNode()->document().frame(); | 155 LocalFrame* frame = result.innerNode()->document().frame(); |
145 EphemeralRange range = frame->rangeForPoint(result.roundedPointInInnerNodeFr ame()); | 156 EphemeralRange range = frame->rangeForPoint(result.roundedPointInInnerNodeFr ame()); |
146 if (range.isNull()) | 157 if (range.isNull()) |
147 return nil; | 158 return nil; |
148 | 159 |
149 // Expand to word under point. | 160 // Expand to word under point. |
150 VisibleSelection selection(range); | 161 VisibleSelection selection(range); |
151 selection.expandUsingGranularity(WordGranularity); | 162 selection.expandUsingGranularity(WordGranularity); |
(...skipping 23 matching lines...) Expand all Loading... | |
175 if (ephemeralRange.isNull()) | 186 if (ephemeralRange.isNull()) |
176 return nil; | 187 return nil; |
177 | 188 |
178 NSAttributedString* result = attributedSubstringFromRange(ephemeralRange); | 189 NSAttributedString* result = attributedSubstringFromRange(ephemeralRange); |
179 if (baselinePoint) | 190 if (baselinePoint) |
180 *baselinePoint = getBaselinePoint(frame->view(), ephemeralRange, result) ; | 191 *baselinePoint = getBaselinePoint(frame->view(), ephemeralRange, result) ; |
181 return result; | 192 return result; |
182 } | 193 } |
183 | 194 |
184 } // namespace blink | 195 } // namespace blink |
OLD | NEW |