Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Appearance settings

Latest commit

 

History

History
History
128 lines (110 loc) · 5.07 KB

File metadata and controls

128 lines (110 loc) · 5.07 KB
Copy raw file
Download raw file
Open symbols panel
Edit and raw actions
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
/*
* Copyright (C) 2006 Rob Buis <buis@kde.org>
* (C) 2008 Nikolas Zimmermann <zimmermann@kde.org>
* Copyright (C) 2008-2021 Apple Inc. All rights reserved.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public License
* along with this library; see the file COPYING.LIB. If not, write to
* the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
* Boston, MA 02110-1301, USA.
*/
#include "config.h"
#include "CSSCursorImageValue.h"
#include "CSSImageSetValue.h"
#include "CSSImageValue.h"
#include "SVGCursorElement.h"
#include "SVGLengthContext.h"
#include "SVGURIReference.h"
#include "StyleBuilderState.h"
#include <wtf/MathExtras.h>
#include <wtf/text/WTFString.h>
namespace WebCore {
CSSCursorImageValue::CSSCursorImageValue(Ref<CSSValue>&& imageValue, const std::optional<IntPoint>& hotSpot, LoadedFromOpaqueSource loadedFromOpaqueSource)
: CSSValue(CursorImageClass)
, m_imageValue(WTFMove(imageValue))
, m_hotSpot(hotSpot)
, m_loadedFromOpaqueSource(loadedFromOpaqueSource)
{
if (is<CSSImageValue>(m_imageValue.get()))
m_originalURL = downcast<CSSImageValue>(m_imageValue.get()).imageURL();
}
Ref<CSSCursorImageValue> CSSCursorImageValue::create(Ref<CSSValue>&& imageValue, const std::optional<IntPoint>& hotSpot, LoadedFromOpaqueSource loadedFromOpaqueSource)
{
return adoptRef(*new CSSCursorImageValue(WTFMove(imageValue), hotSpot, loadedFromOpaqueSource));
}
CSSCursorImageValue::~CSSCursorImageValue()
{
for (auto* element : m_cursorElements)
element->removeClient(*this);
}
String CSSCursorImageValue::customCSSText() const
{
String text = m_imageValue.get().cssText();
if (!m_hotSpot)
return text;
return makeString(text, ' ', m_hotSpot->x(), ' ', m_hotSpot->y());
}
// FIXME: Should this function take a TreeScope instead?
SVGCursorElement* CSSCursorImageValue::updateCursorElement(const Document& document)
{
auto element = SVGURIReference::targetElementFromIRIString(m_originalURL.string(), document).element;
if (!is<SVGCursorElement>(element))
return nullptr;
// FIXME: Not right to keep old cursor elements as clients. The new one should replace the old, not join it in a set.
auto& cursorElement = downcast<SVGCursorElement>(*element);
if (m_cursorElements.add(&cursorElement).isNewEntry) {
cursorElementChanged(cursorElement);
cursorElement.addClient(*this);
}
return &cursorElement;
}
void CSSCursorImageValue::cursorElementRemoved(SVGCursorElement& cursorElement)
{
// FIXME: Not right to stay a client of a cursor element until the element is destroyed. We'd want to stop being a client once it's no longer a valid target, like when it's disconnected.
m_cursorElements.remove(&cursorElement);
}
void CSSCursorImageValue::cursorElementChanged(SVGCursorElement& cursorElement)
{
// FIXME: Seems wrong that changing an old cursor element, one that that is no longer the target, changes the hot spot.
// FIXME: This will override a hot spot that was specified in CSS, which is probably incorrect.
// FIXME: Should we clamp from float to int instead of just casting here?
SVGLengthContext lengthContext(nullptr);
m_hotSpot = IntPoint {
static_cast<int>(std::round(cursorElement.x().value(lengthContext))),
static_cast<int>(std::round(cursorElement.y().value(lengthContext)))
};
// FIXME: Why doesn't this funtion check for a change to the href of the cursor element? Why would we dynamically track changes to x/y but not href?
}
ImageWithScale CSSCursorImageValue::selectBestFitImage(const Document& document)
{
if (is<CSSImageSetValue>(m_imageValue.get()))
return downcast<CSSImageSetValue>(m_imageValue.get()).selectBestFitImage(document);
if (auto* cursorElement = updateCursorElement(document)) {
auto location = document.completeURL(cursorElement->href());
if (location != downcast<CSSImageValue>(m_imageValue.get()).imageURL())
m_imageValue = CSSImageValue::create(WTFMove(location), m_loadedFromOpaqueSource);
}
return { m_imageValue.ptr() , 1 };
}
bool CSSCursorImageValue::equals(const CSSCursorImageValue& other) const
{
return m_hotSpot == other.m_hotSpot && compareCSSValue(m_imageValue, other.m_imageValue);
}
Ref<CSSCursorImageValue> CSSCursorImageValue::valueWithStylesResolved(Style::BuilderState& state)
{
auto imageValue = state.resolveImageStyles(m_imageValue.get());
if (imageValue.ptr() == m_imageValue.ptr())
return *this;
return create(WTFMove(imageValue), m_hotSpot, m_loadedFromOpaqueSource);
}
} // namespace WebCore
Morty Proxy This is a proxified and sanitized view of the page, visit original site.