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

Side by Side Diff: third_party/WebKit/Source/core/fetch/CSSStyleSheetResource.h

Issue 1976463003: Preload scan external CSS for @import (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: actually include crasher fix Created 4 years, 7 months 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) 1998 Lars Knoll (knoll@mpi-hd.mpg.de) 2 Copyright (C) 1998 Lars Knoll (knoll@mpi-hd.mpg.de)
3 Copyright (C) 2001 Dirk Mueller <mueller@kde.org> 3 Copyright (C) 2001 Dirk Mueller <mueller@kde.org>
4 Copyright (C) 2006 Samuel Weinig (sam.weinig@gmail.com) 4 Copyright (C) 2006 Samuel Weinig (sam.weinig@gmail.com)
5 Copyright (C) 2004, 2005, 2006, 2007, 2008 Apple Inc. All rights reserved. 5 Copyright (C) 2004, 2005, 2006, 2007, 2008 Apple Inc. All rights reserved.
6 6
7 This library is free software; you can redistribute it and/or 7 This library is free software; you can redistribute it and/or
8 modify it under the terms of the GNU Library General Public 8 modify it under the terms of the GNU Library General Public
9 License as published by the Free Software Foundation; either 9 License as published by the Free Software Foundation; either
10 version 2 of the License, or (at your option) any later version. 10 version 2 of the License, or (at your option) any later version.
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after
43 enum class MIMETypeCheck { Strict, Lax }; 43 enum class MIMETypeCheck { Strict, Lax };
44 44
45 static CSSStyleSheetResource* fetch(FetchRequest&, ResourceFetcher*); 45 static CSSStyleSheetResource* fetch(FetchRequest&, ResourceFetcher*);
46 static CSSStyleSheetResource* createForTest(const ResourceRequest&, const St ring& charset); 46 static CSSStyleSheetResource* createForTest(const ResourceRequest&, const St ring& charset);
47 47
48 ~CSSStyleSheetResource() override; 48 ~CSSStyleSheetResource() override;
49 DECLARE_VIRTUAL_TRACE(); 49 DECLARE_VIRTUAL_TRACE();
50 50
51 const String sheetText(MIMETypeCheck = MIMETypeCheck::Strict) const; 51 const String sheetText(MIMETypeCheck = MIMETypeCheck::Strict) const;
52 52
53 void didAddClient(ResourceClient*) override; 53 void didAddClient(ResourceClient*) override;
hiroshige 2016/06/17 12:15:17 We also have to modify didAddClient() if we want t
Charlie Harrison 2016/07/13 18:18:14 Done.
54 54
55 StyleSheetContents* restoreParsedStyleSheet(const CSSParserContext&); 55 StyleSheetContents* restoreParsedStyleSheet(const CSSParserContext&);
56 void saveParsedStyleSheet(StyleSheetContents*); 56 void saveParsedStyleSheet(StyleSheetContents*);
57 57
58 void appendData(const char* data, size_t length) override;
59
58 protected: 60 protected:
59 bool isSafeToUnlock() const override; 61 bool isSafeToUnlock() const override;
60 void destroyDecodedDataIfPossible() override; 62 void destroyDecodedDataIfPossible() override;
61 void destroyDecodedDataForFailedRevalidation() override { destroyDecodedData IfPossible(); } 63 void destroyDecodedDataForFailedRevalidation() override { destroyDecodedData IfPossible(); }
62 64
63 private: 65 private:
64 class CSSStyleSheetResourceFactory : public ResourceFactory { 66 class CSSStyleSheetResourceFactory : public ResourceFactory {
65 public: 67 public:
66 CSSStyleSheetResourceFactory() 68 CSSStyleSheetResourceFactory()
67 : ResourceFactory(Resource::CSSStyleSheet) { } 69 : ResourceFactory(Resource::CSSStyleSheet) { }
68 70
69 Resource* create(const ResourceRequest& request, const ResourceLoaderOpt ions& options, const String& charset) const override 71 Resource* create(const ResourceRequest& request, const ResourceLoaderOpt ions& options, const String& charset) const override
70 { 72 {
71 return new CSSStyleSheetResource(request, options, charset); 73 return new CSSStyleSheetResource(request, options, charset);
72 } 74 }
73 }; 75 };
74 CSSStyleSheetResource(const ResourceRequest&, const ResourceLoaderOptions&, const String& charset); 76 CSSStyleSheetResource(const ResourceRequest&, const ResourceLoaderOptions&, const String& charset);
75 77
76 bool canUseSheet(MIMETypeCheck) const; 78 bool canUseSheet(MIMETypeCheck) const;
77 void checkNotify() override; 79 void checkNotify() override;
78 80
79 void setParsedStyleSheetCache(StyleSheetContents*); 81 void setParsedStyleSheetCache(StyleSheetContents*);
80 82
81 String m_decodedSheetText; 83 String m_decodedSheetText;
82 84
83 Member<StyleSheetContents> m_parsedStyleSheetCache; 85 Member<StyleSheetContents> m_parsedStyleSheetCache;
86
87 bool m_didNotifyFirstData;
84 }; 88 };
85 89
86 DEFINE_RESOURCE_TYPE_CASTS(CSSStyleSheet); 90 DEFINE_RESOURCE_TYPE_CASTS(CSSStyleSheet);
87 91
88 } // namespace blink 92 } // namespace blink
89 93
90 #endif 94 #endif
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698