Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(60)

Side by Side Diff: sky/engine/core/html/imports/HTMLImportLoader.cpp

Issue 703593003: Move exports from Document to Module (Closed) Base URL: git@github.com:domokit/mojo.git@master
Patch Set: Created 6 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright (C) 2013 Google Inc. All rights reserved. 2 * Copyright (C) 2013 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 are 5 * modification, are permitted provided that the following conditions are
6 * met: 6 * met:
7 * 7 *
8 * * Redistributions of source code must retain the above copyright 8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer. 9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above 10 * * Redistributions in binary form must reproduce the above
(...skipping 13 matching lines...) Expand all
24 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 24 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 25 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 26 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 28 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29 */ 29 */
30 30
31 #include "config.h" 31 #include "config.h"
32 #include "core/html/imports/HTMLImportLoader.h" 32 #include "core/html/imports/HTMLImportLoader.h"
33 33
34 #include "core/app/Module.h"
34 #include "core/dom/Document.h" 35 #include "core/dom/Document.h"
35 #include "core/dom/DocumentParser.h" 36 #include "core/dom/DocumentParser.h"
36 #include "core/dom/StyleEngine.h" 37 #include "core/dom/StyleEngine.h"
37 #include "core/dom/custom/CustomElementSyncMicrotaskQueue.h" 38 #include "core/dom/custom/CustomElementSyncMicrotaskQueue.h"
38 #include "core/html/HTMLDocument.h" 39 #include "core/html/HTMLDocument.h"
39 #include "core/html/imports/HTMLImportChild.h" 40 #include "core/html/imports/HTMLImportChild.h"
40 #include "core/html/imports/HTMLImportsController.h" 41 #include "core/html/imports/HTMLImportsController.h"
41 42
42 namespace blink { 43 namespace blink {
43 44
(...skipping 13 matching lines...) Expand all
57 58
58 #if !ENABLE(OILPAN) 59 #if !ENABLE(OILPAN)
59 void HTMLImportLoader::importDestroyed() 60 void HTMLImportLoader::importDestroyed()
60 { 61 {
61 clear(); 62 clear();
62 } 63 }
63 64
64 void HTMLImportLoader::clear() 65 void HTMLImportLoader::clear()
65 { 66 {
66 m_controller = nullptr; 67 m_controller = nullptr;
68 m_module.clear();
67 if (m_document) { 69 if (m_document) {
68 m_document->setImportsController(0); 70 m_document->setImportsController(0);
69 m_document->cancelParsing(); 71 m_document->cancelParsing();
70 m_document.clear(); 72 m_document.clear();
71 } 73 }
72 m_fetcher.clear(); 74 m_fetcher.clear();
73 } 75 }
74 #endif 76 #endif
75 77
76 void HTMLImportLoader::startLoading(const KURL& url) 78 void HTMLImportLoader::startLoading(const KURL& url)
(...skipping 10 matching lines...) Expand all
87 m_controller->master()->addMessage(consoleMessage); 89 m_controller->master()->addMessage(consoleMessage);
88 setState(StateError); 90 setState(StateError);
89 return; 91 return;
90 } 92 }
91 setState(startWritingAndParsing(response.Pass())); 93 setState(startWritingAndParsing(response.Pass()));
92 } 94 }
93 95
94 HTMLImportLoader::State HTMLImportLoader::startWritingAndParsing(mojo::URLRespon sePtr response) 96 HTMLImportLoader::State HTMLImportLoader::startWritingAndParsing(mojo::URLRespon sePtr response)
95 { 97 {
96 ASSERT(!m_imports.isEmpty()); 98 ASSERT(!m_imports.isEmpty());
99 WeakPtr<Document> contextDocument = m_controller->master()->contextDocument( );
100 ASSERT(contextDocument.get());
97 KURL url(ParsedURLString, String::fromUTF8(response->url)); 101 KURL url(ParsedURLString, String::fromUTF8(response->url));
98 DocumentInit init = DocumentInit(url, 0, m_controller->master()->contextDocu ment(), m_controller) 102 DocumentInit init = DocumentInit(url, 0, contextDocument, m_controller)
99 .withRegistrationContext(m_controller->master()->registrationContext()); 103 .withRegistrationContext(m_controller->master()->registrationContext());
100 m_document = HTMLDocument::create(init); 104 m_document = HTMLDocument::create(init);
105 m_module = Module::create(contextDocument.get(), nullptr, m_document.get(), url.string());
101 m_document->startParsing(); 106 m_document->startParsing();
102 m_document->parser()->parse(response->body.Pass()); 107 m_document->parser()->parse(response->body.Pass());
103 return StateLoading; 108 return StateLoading;
104 } 109 }
105 110
106 HTMLImportLoader::State HTMLImportLoader::finishWriting() 111 HTMLImportLoader::State HTMLImportLoader::finishWriting()
107 { 112 {
108 return StateWritten; 113 return StateWritten;
109 } 114 }
110 115
(...skipping 84 matching lines...) Expand 10 before | Expand all | Expand 10 after
195 { 200 {
196 visitor->trace(m_controller); 201 visitor->trace(m_controller);
197 #if ENABLE(OILPAN) 202 #if ENABLE(OILPAN)
198 visitor->trace(m_imports); 203 visitor->trace(m_imports);
199 #endif 204 #endif
200 visitor->trace(m_document); 205 visitor->trace(m_document);
201 visitor->trace(m_microtaskQueue); 206 visitor->trace(m_microtaskQueue);
202 } 207 }
203 208
204 } // namespace blink 209 } // namespace blink
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698