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 |
(...skipping 15 matching lines...) Expand all Loading... |
26 #include "config.h" | 26 #include "config.h" |
27 #include "core/html/parser/HTMLViewSourceParser.h" | 27 #include "core/html/parser/HTMLViewSourceParser.h" |
28 | 28 |
29 #include "core/dom/DOMImplementation.h" | 29 #include "core/dom/DOMImplementation.h" |
30 #include "core/html/parser/HTMLParserIdioms.h" | 30 #include "core/html/parser/HTMLParserIdioms.h" |
31 #include "core/html/parser/HTMLParserOptions.h" | 31 #include "core/html/parser/HTMLParserOptions.h" |
32 #include "core/html/parser/HTMLToken.h" | 32 #include "core/html/parser/HTMLToken.h" |
33 | 33 |
34 namespace WebCore { | 34 namespace WebCore { |
35 | 35 |
| 36 // FIXME: HTMLViewSourceDocument should be a reference. |
36 HTMLViewSourceParser::HTMLViewSourceParser(HTMLViewSourceDocument* document, con
st String& mimeType) | 37 HTMLViewSourceParser::HTMLViewSourceParser(HTMLViewSourceDocument* document, con
st String& mimeType) |
37 : DecodedDataDocumentParser(document) | 38 : DecodedDataDocumentParser(*document) |
38 , m_tokenizer(HTMLTokenizer::create(HTMLParserOptions(document))) | 39 , m_tokenizer(HTMLTokenizer::create(HTMLParserOptions(document))) |
39 { | 40 { |
40 if (mimeType != "text/html" && !DOMImplementation::isXMLMIMEType(mimeType)) | 41 if (mimeType != "text/html" && !DOMImplementation::isXMLMIMEType(mimeType)) |
41 m_tokenizer->setState(HTMLTokenizer::PLAINTEXTState); | 42 m_tokenizer->setState(HTMLTokenizer::PLAINTEXTState); |
42 } | 43 } |
43 | 44 |
44 void HTMLViewSourceParser::pumpTokenizer() | 45 void HTMLViewSourceParser::pumpTokenizer() |
45 { | 46 { |
46 while (true) { | 47 while (true) { |
47 m_sourceTracker.start(m_input.current(), m_tokenizer.get(), m_token); | 48 m_sourceTracker.start(m_input.current(), m_tokenizer.get(), m_token); |
(...skipping 18 matching lines...) Expand all Loading... |
66 | 67 |
67 void HTMLViewSourceParser::finish() | 68 void HTMLViewSourceParser::finish() |
68 { | 69 { |
69 if (!m_input.haveSeenEndOfFile()) | 70 if (!m_input.haveSeenEndOfFile()) |
70 m_input.markEndOfFile(); | 71 m_input.markEndOfFile(); |
71 pumpTokenizer(); | 72 pumpTokenizer(); |
72 document()->finishedParsing(); | 73 document()->finishedParsing(); |
73 } | 74 } |
74 | 75 |
75 } | 76 } |
OLD | NEW |