OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2011 Google Inc. All rights reserved. | 2 * Copyright (C) 2011 Google Inc. All rights reserved. |
3 * | 3 * |
4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
5 * modification, are permitted provided that the following conditions | 5 * modification, are permitted provided that the following conditions |
6 * are met: | 6 * are met: |
7 * 1. Redistributions of source code must retain the above copyright | 7 * 1. Redistributions of source code must retain the above copyright |
8 * notice, this list of conditions and the following disclaimer. | 8 * notice, this list of conditions and the following disclaimer. |
9 * 2. Redistributions in binary form must reproduce the above copyright | 9 * 2. Redistributions in binary form must reproduce the above copyright |
10 * notice, this list of conditions and the following disclaimer in the | 10 * notice, this list of conditions and the following disclaimer in the |
11 * documentation and/or other materials provided with the distribution. | 11 * documentation and/or other materials provided with the distribution. |
12 * | 12 * |
13 * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY | 13 * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY |
14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | 14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR | 15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR |
16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR | 16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR |
17 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, | 17 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, |
18 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, | 18 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, |
19 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR | 19 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR |
20 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY | 20 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY |
21 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 21 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
24 */ | 24 */ |
25 | 25 |
26 #include "config.h" | 26 #include "config.h" |
| 27 #include "core/html/track/TextTrackCueList.h" |
27 | 28 |
28 #include "core/html/track/TextTrackCueList.h" | 29 #include "wtf/StdLibExtras.h" |
29 | 30 |
30 namespace blink { | 31 namespace blink { |
31 | 32 |
32 TextTrackCueList::TextTrackCueList() | 33 TextTrackCueList::TextTrackCueList() |
33 { | 34 { |
34 } | 35 } |
35 | 36 |
36 DEFINE_EMPTY_DESTRUCTOR_WILL_BE_REMOVED(TextTrackCueList); | 37 DEFINE_EMPTY_DESTRUCTOR_WILL_BE_REMOVED(TextTrackCueList); |
37 | 38 |
38 unsigned long TextTrackCueList::length() const | 39 unsigned long TextTrackCueList::length() const |
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
73 m_activeCues->add(cue); | 74 m_activeCues->add(cue); |
74 } | 75 } |
75 return m_activeCues.get(); | 76 return m_activeCues.get(); |
76 } | 77 } |
77 | 78 |
78 bool TextTrackCueList::add(PassRefPtrWillBeRawPtr<TextTrackCue> cue) | 79 bool TextTrackCueList::add(PassRefPtrWillBeRawPtr<TextTrackCue> cue) |
79 { | 80 { |
80 ASSERT(cue->startTime() >= 0); | 81 ASSERT(cue->startTime() >= 0); |
81 ASSERT(cue->endTime() >= 0); | 82 ASSERT(cue->endTime() >= 0); |
82 | 83 |
83 return add(cue, 0, m_list.size()); | 84 // Maintain text track cue order: |
| 85 // https://html.spec.whatwg.org/#text-track-cue-order |
| 86 size_t index = findInsertionIndex(cue.get()); |
| 87 |
| 88 // FIXME: The cue should not exist in the list in the first place. |
| 89 if (!m_list.isEmpty() && (index > 0) && (m_list[index - 1].get() == cue.get(
))) |
| 90 return false; |
| 91 |
| 92 m_list.insert(index, cue); |
| 93 invalidateCueIndexes(index); |
| 94 return true; |
84 } | 95 } |
85 | 96 |
86 bool TextTrackCueList::add(PassRefPtrWillBeRawPtr<TextTrackCue> prpCue, size_t s
tart, size_t end) | 97 static bool cueIsBefore(const TextTrackCue* cue, PassRefPtrWillBeRawPtr<TextTrac
kCue> otherCue) |
87 { | 98 { |
88 ASSERT_WITH_SECURITY_IMPLICATION(start <= m_list.size()); | 99 if (cue->startTime() < otherCue->startTime()) |
89 ASSERT_WITH_SECURITY_IMPLICATION(end <= m_list.size()); | 100 return true; |
90 | 101 |
91 // Maintain text track cue order: | 102 return cue->startTime() == otherCue->startTime() && cue->endTime() > otherCu
e->endTime(); |
92 // http://www.whatwg.org/specs/web-apps/current-work/#text-track-cue-order | 103 } |
93 RefPtrWillBeRawPtr<TextTrackCue> cue = prpCue; | |
94 if (start == end) { | |
95 if (!m_list.isEmpty() && (start > 0) && (m_list[start - 1].get() == cue.
get())) | |
96 return false; | |
97 | 104 |
98 m_list.insert(start, cue); | 105 size_t TextTrackCueList::findInsertionIndex(const TextTrackCue* cueToInsert) con
st |
99 invalidateCueIndexes(start); | 106 { |
100 return true; | 107 auto it = std::upper_bound(m_list.begin(), m_list.end(), cueToInsert, cueIsB
efore); |
101 } | 108 size_t index = safeCast<size_t>(it - m_list.begin()); |
102 | 109 ASSERT_WITH_SECURITY_IMPLICATION(index <= m_list.size()); |
103 size_t index = (start + end) / 2; | 110 return index; |
104 if (cue->startTime() < m_list[index]->startTime() || (cue->startTime() == m_
list[index]->startTime() && cue->endTime() > m_list[index]->endTime())) | |
105 return add(cue.release(), start, index); | |
106 | |
107 return add(cue.release(), index + 1, end); | |
108 } | 111 } |
109 | 112 |
110 bool TextTrackCueList::remove(TextTrackCue* cue) | 113 bool TextTrackCueList::remove(TextTrackCue* cue) |
111 { | 114 { |
112 size_t index = m_list.find(cue); | 115 size_t index = m_list.find(cue); |
113 if (index == kNotFound) | 116 if (index == kNotFound) |
114 return false; | 117 return false; |
115 | 118 |
116 m_list.remove(index); | 119 m_list.remove(index); |
| 120 // FIXME: While removing a cue does not invalidate the cue order, it does |
| 121 // make it more difficult to maintain the invariant, so should probably |
| 122 // just invalidate here as well. |
117 return true; | 123 return true; |
118 } | 124 } |
119 | 125 |
120 bool TextTrackCueList::updateCueIndex(TextTrackCue* cue) | 126 void TextTrackCueList::updateCueIndex(TextTrackCue* cue) |
121 { | 127 { |
122 size_t index = m_list.find(cue); | 128 if (!remove(cue)) |
123 if (index == kNotFound) | 129 return; |
124 return false; | |
125 | 130 |
126 cue->setIsActive(false); | 131 cue->setIsActive(false); |
127 cue->removeDisplayTree(); | 132 cue->removeDisplayTree(); |
128 | 133 |
129 m_list.remove(index); | 134 // FIXME: If moving the cue such that its index in list increases, then |
130 | 135 // what happens with the cached index on cues in the range [oldIndex, |
131 return add(cue); | 136 // newIndex)? (Some of the indices will be "safe", but there'll be a risk |
| 137 // that the lazy update via cueIndex() yields duplicates/incorrect order.) |
| 138 add(cue); |
132 } | 139 } |
133 | 140 |
134 void TextTrackCueList::clear() | 141 void TextTrackCueList::clear() |
135 { | 142 { |
136 m_list.clear(); | 143 m_list.clear(); |
137 } | 144 } |
138 | 145 |
139 void TextTrackCueList::invalidateCueIndexes(size_t start) | 146 void TextTrackCueList::invalidateCueIndexes(size_t start) |
140 { | 147 { |
| 148 // FIXME: When iterating cues we could as well update their cached indices t
oo. |
141 for (size_t i = start; i < m_list.size(); ++i) | 149 for (size_t i = start; i < m_list.size(); ++i) |
142 m_list[i]->invalidateCueIndex(); | 150 m_list[i]->invalidateCueIndex(); |
143 } | 151 } |
144 | 152 |
145 DEFINE_TRACE(TextTrackCueList) | 153 DEFINE_TRACE(TextTrackCueList) |
146 { | 154 { |
147 visitor->trace(m_list); | 155 visitor->trace(m_list); |
148 visitor->trace(m_activeCues); | 156 visitor->trace(m_activeCues); |
149 } | 157 } |
150 | 158 |
151 } // namespace blink | 159 } // namespace blink |
OLD | NEW |