OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright (C) 2008 Apple Inc. All Rights Reserved. | 2 * Copyright (C) 2008 Apple Inc. All Rights Reserved. |
3 * Copyright (C) 2010 Google Inc. All Rights Reserved. | 3 * Copyright (C) 2010 Google Inc. All Rights Reserved. |
4 * | 4 * |
5 * Redistribution and use in source and binary forms, with or without | 5 * Redistribution and use in source and binary forms, with or without |
6 * modification, are permitted provided that the following conditions | 6 * modification, are permitted provided that the following conditions |
7 * are met: | 7 * are met: |
8 * 1. Redistributions of source code must retain the above copyright | 8 * 1. 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 * 2. Redistributions in binary form must reproduce the above copyright | 10 * 2. Redistributions in binary form must reproduce the above copyright |
11 * notice, this list of conditions and the following disclaimer in the | 11 * notice, this list of conditions and the following disclaimer in the |
12 * documentation and/or other materials provided with the distribution. | 12 * documentation and/or other materials provided with the distribution. |
13 * | 13 * |
14 * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY | 14 * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY |
15 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | 15 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
16 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR | 16 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR |
17 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR | 17 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR |
18 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, | 18 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, |
19 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, | 19 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, |
20 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR | 20 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR |
21 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY | 21 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY |
22 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 22 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
23 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 23 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
24 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 24 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
25 */ | 25 */ |
26 | 26 |
27 #ifndef CSSPreloadScanner_h | 27 #ifndef CSSPreloadScanner_h |
28 #define CSSPreloadScanner_h | 28 #define CSSPreloadScanner_h |
29 | 29 |
30 #include "core/html/parser/HTMLResourcePreloader.h" | 30 #include "core/fetch/StyleSheetResourceClient.h" |
31 #include "core/html/parser/HTMLToken.h" | 31 #include "core/html/parser/HTMLToken.h" |
32 #include "core/html/parser/PreloadRequest.h" | |
32 #include "wtf/text/StringBuilder.h" | 33 #include "wtf/text/StringBuilder.h" |
33 | 34 |
34 namespace blink { | 35 namespace blink { |
35 | 36 |
36 class SegmentedString; | 37 class SegmentedString; |
38 class HTMLResourcePreloader; | |
37 | 39 |
38 class CSSPreloadScanner { | 40 class CSSPreloadScanner { |
41 WTF_MAKE_NONCOPYABLE(CSSPreloadScanner); | |
39 DISALLOW_NEW(); | 42 DISALLOW_NEW(); |
Yoav Weiss
2016/03/30 21:38:31
spurious change or is the order here meaningful?
Charlie Harrison
2016/03/31 03:59:59
Oops, spurious. Sorry.
| |
40 WTF_MAKE_NONCOPYABLE(CSSPreloadScanner); | |
41 public: | 43 public: |
42 CSSPreloadScanner(); | 44 CSSPreloadScanner(); |
43 ~CSSPreloadScanner(); | 45 ~CSSPreloadScanner(); |
44 | 46 |
45 void reset(); | 47 void reset(); |
46 | 48 |
47 void scan(const HTMLToken::DataVector&, const SegmentedString&, PreloadReque stStream&, const KURL&); | 49 void scan(const HTMLToken::DataVector&, const SegmentedString&, PreloadReque stStream&, const KURL&); |
48 void scan(const String&, const SegmentedString&, PreloadRequestStream&, cons t KURL&); | 50 void scan(const String&, const SegmentedString&, PreloadRequestStream&, cons t KURL&); |
49 | 51 |
50 void setReferrerPolicy(const ReferrerPolicy); | 52 void setReferrerPolicy(const ReferrerPolicy); |
(...skipping 22 matching lines...) Expand all Loading... | |
73 StringBuilder m_rule; | 75 StringBuilder m_rule; |
74 StringBuilder m_ruleValue; | 76 StringBuilder m_ruleValue; |
75 | 77 |
76 ReferrerPolicy m_referrerPolicy = ReferrerPolicyDefault; | 78 ReferrerPolicy m_referrerPolicy = ReferrerPolicyDefault; |
77 | 79 |
78 // Below members only non-null during scan() | 80 // Below members only non-null during scan() |
79 PreloadRequestStream* m_requests = nullptr; | 81 PreloadRequestStream* m_requests = nullptr; |
80 const KURL* m_predictedBaseElementURL = nullptr; | 82 const KURL* m_predictedBaseElementURL = nullptr; |
81 }; | 83 }; |
82 | 84 |
85 // Each CSSPreloaderResourceClient keeps track of a single CSS resource, and | |
86 // drives a CSSPreloadScanner as raw data arrives for it. This lets us preload | |
87 // @import tags before parsing. | |
88 class CSSPreloaderResourceClient : public StyleSheetResourceClient { | |
89 public: | |
90 CSSPreloaderResourceClient(HTMLResourcePreloader*); | |
91 void didAppendData(const CSSStyleSheetResource*) override; | |
92 String debugName() const override { return "CSSPreloaderResourceClient"; } | |
93 | |
94 private: | |
95 void preloadChunk(const String& chunk, const CSSStyleSheetResource*); | |
96 CSSPreloadScanner m_cssPreloadScanner; | |
97 RawPtrWillBeWeakPersistent<HTMLResourcePreloader> m_preloader; | |
98 size_t m_streamPosition; | |
99 }; | |
100 | |
83 } // namespace blink | 101 } // namespace blink |
84 | 102 |
85 #endif | 103 #endif |
OLD | NEW |