Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright (C) 2010 Google, Inc. All Rights Reserved. | 2 * Copyright (C) 2010 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 INC. ``AS IS'' AND ANY | 13 * THIS SOFTWARE IS PROVIDED BY APPLE 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 INC. OR | 16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE 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/dom/DocumentParser.h" | 27 #include "core/dom/DocumentParser.h" |
| 28 | 28 |
| 29 #include "core/dom/Document.h" | 29 #include "core/dom/Document.h" |
| 30 #include "core/dom/DocumentParserClient.h" | |
| 30 #include "core/html/parser/TextResourceDecoder.h" | 31 #include "core/html/parser/TextResourceDecoder.h" |
| 31 #include "wtf/Assertions.h" | 32 #include "wtf/Assertions.h" |
| 32 | 33 |
| 33 namespace blink { | 34 namespace blink { |
| 34 | 35 |
| 35 DocumentParser::DocumentParser(Document* document) | 36 DocumentParser::DocumentParser(Document* document) |
| 36 : m_state(ParsingState) | 37 : m_state(ParsingState) |
| 37 , m_documentWasLoadedAsPartOfNavigation(false) | 38 , m_documentWasLoadedAsPartOfNavigation(false) |
| 38 , m_document(document) | 39 , m_document(document) |
| 39 { | 40 { |
| 40 ASSERT(document); | 41 ASSERT(document); |
| 41 } | 42 } |
| 42 | 43 |
| 43 DocumentParser::~DocumentParser() | 44 DocumentParser::~DocumentParser() |
| 44 { | 45 { |
| 45 #if !ENABLE(OILPAN) | 46 #if !ENABLE(OILPAN) |
| 46 // Document is expected to call detach() before releasing its ref. | 47 // Document is expected to call detach() before releasing its ref. |
| 47 // This ASSERT is slightly awkward for parsers with a fragment case | 48 // This ASSERT is slightly awkward for parsers with a fragment case |
| 48 // as there is no Document to release the ref. | 49 // as there is no Document to release the ref. |
| 49 ASSERT(!m_document); | 50 ASSERT(!m_document); |
| 50 #endif | 51 #endif |
| 51 } | 52 } |
| 52 | 53 |
| 53 void DocumentParser::trace(Visitor* visitor) | 54 void DocumentParser::trace(Visitor* visitor) |
| 54 { | 55 { |
| 55 visitor->trace(m_document); | 56 visitor->trace(m_document); |
| 57 // HELPME(oilpan): Below doesn't compile | |
| 58 // visitor->trace(m_clients); | |
|
kouhei (in TOK)
2014/09/03 22:40:41
This gives me an error, but I don't know how to re
kouhei (in TOK)
2014/09/04 21:08:01
Resolved. We needed a #if ENABLE(OILPAN) here, as
| |
| 56 } | 59 } |
| 57 | 60 |
| 58 void DocumentParser::setDecoder(PassOwnPtr<TextResourceDecoder>) | 61 void DocumentParser::setDecoder(PassOwnPtr<TextResourceDecoder>) |
| 59 { | 62 { |
| 60 ASSERT_NOT_REACHED(); | 63 ASSERT_NOT_REACHED(); |
| 61 } | 64 } |
| 62 | 65 |
| 63 TextResourceDecoder* DocumentParser::decoder() | 66 TextResourceDecoder* DocumentParser::decoder() |
| 64 { | 67 { |
| 65 return 0; | 68 return 0; |
| 66 } | 69 } |
| 67 | 70 |
| 68 void DocumentParser::prepareToStopParsing() | 71 void DocumentParser::prepareToStopParsing() |
| 69 { | 72 { |
| 70 ASSERT(m_state == ParsingState); | 73 ASSERT(m_state == ParsingState); |
| 71 m_state = StoppingState; | 74 m_state = StoppingState; |
| 72 } | 75 } |
| 73 | 76 |
| 74 void DocumentParser::stopParsing() | 77 void DocumentParser::stopParsing() |
| 75 { | 78 { |
| 76 m_state = StoppedState; | 79 m_state = StoppedState; |
| 80 | |
| 81 // Clients may be removed while in the loop. Make a snapshot for iteration. | |
| 82 WillBeHeapVector<RawPtrWillBeMember<DocumentParserClient> > clientsSnapshot; | |
| 83 copyToVector(m_clients, clientsSnapshot); | |
| 84 | |
| 85 for (WillBeHeapVector<RawPtrWillBeMember<DocumentParserClient> >::const_iter ator it = clientsSnapshot.begin(), itEnd = clientsSnapshot.end(); it != itEnd; + +it) { | |
| 86 DocumentParserClient* client = *it; | |
| 87 if (!m_clients.contains(client)) | |
| 88 continue; | |
| 89 | |
| 90 client->notifyParserStopped(); | |
| 91 } | |
| 77 } | 92 } |
| 78 | 93 |
| 79 void DocumentParser::detach() | 94 void DocumentParser::detach() |
| 80 { | 95 { |
| 81 m_state = DetachedState; | 96 m_state = DetachedState; |
| 82 m_document = nullptr; | 97 m_document = nullptr; |
| 83 } | 98 } |
| 84 | 99 |
| 85 void DocumentParser::suspendScheduledTasks() | 100 void DocumentParser::suspendScheduledTasks() |
| 86 { | 101 { |
| 87 } | 102 } |
| 88 | 103 |
| 89 void DocumentParser::resumeScheduledTasks() | 104 void DocumentParser::resumeScheduledTasks() |
| 90 { | 105 { |
| 91 } | 106 } |
| 92 | 107 |
| 108 void DocumentParser::addClient(DocumentParserClient* client) | |
| 109 { | |
| 110 m_clients.add(client); | |
| 111 } | |
| 112 | |
| 113 void DocumentParser::removeClient(DocumentParserClient* client) | |
| 114 { | |
| 115 m_clients.remove(client); | |
| 116 } | |
| 117 | |
| 93 }; | 118 }; |
| 94 | 119 |
| OLD | NEW |