OLD | NEW |
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) 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011 Apple Inc. All
rights reserved. | 4 Copyright (C) 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011 Apple Inc. All
rights reserved. |
5 Copyright (C) 2009 Torch Mobile Inc. http://www.torchmobile.com/ | 5 Copyright (C) 2009 Torch Mobile Inc. http://www.torchmobile.com/ |
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 50 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
61 // The ResourceFetcher provides a per-context interface to the MemoryCache | 61 // The ResourceFetcher provides a per-context interface to the MemoryCache |
62 // and enforces a bunch of security checks and rules for resource revalidation. | 62 // and enforces a bunch of security checks and rules for resource revalidation. |
63 // Its lifetime is roughly per-DocumentLoader, in that it is generally created | 63 // Its lifetime is roughly per-DocumentLoader, in that it is generally created |
64 // in the DocumentLoader constructor and loses its ability to generate network | 64 // in the DocumentLoader constructor and loses its ability to generate network |
65 // requests when the DocumentLoader is destroyed. Documents also hold a pointer | 65 // requests when the DocumentLoader is destroyed. Documents also hold a pointer |
66 // to ResourceFetcher for their lifetime (and will create one if they | 66 // to ResourceFetcher for their lifetime (and will create one if they |
67 // are initialized without a LocalFrame), so a Document can keep a ResourceFetch
er | 67 // are initialized without a LocalFrame), so a Document can keep a ResourceFetch
er |
68 // alive past detach if scripts still reference the Document. | 68 // alive past detach if scripts still reference the Document. |
69 class CORE_EXPORT ResourceFetcher : public GarbageCollectedFinalized<ResourceFet
cher> { | 69 class CORE_EXPORT ResourceFetcher : public GarbageCollectedFinalized<ResourceFet
cher> { |
70 WTF_MAKE_NONCOPYABLE(ResourceFetcher); | 70 WTF_MAKE_NONCOPYABLE(ResourceFetcher); |
| 71 WILL_BE_USING_PRE_FINALIZER(ResourceFetcher, clearPreloads); |
71 public: | 72 public: |
72 static ResourceFetcher* create(FetchContext* context) { return new ResourceF
etcher(context); } | 73 static ResourceFetcher* create(FetchContext* context) { return new ResourceF
etcher(context); } |
73 virtual ~ResourceFetcher(); | 74 virtual ~ResourceFetcher(); |
74 DECLARE_VIRTUAL_TRACE(); | 75 DECLARE_VIRTUAL_TRACE(); |
75 | 76 |
76 ResourcePtr<Resource> requestResource(FetchRequest&, const ResourceFactory&)
; | 77 ResourcePtr<Resource> requestResource(FetchRequest&, const ResourceFactory&)
; |
77 | 78 |
78 Resource* cachedResource(const KURL&) const; | 79 Resource* cachedResource(const KURL&) const; |
79 | 80 |
80 typedef HashMap<String, ResourcePtr<Resource>> DocumentResourceMap; | 81 typedef HashMap<String, ResourcePtr<Resource>> DocumentResourceMap; |
(...skipping 158 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
239 m_loader->m_allowStaleResources = m_previousState; | 240 m_loader->m_allowStaleResources = m_previousState; |
240 } | 241 } |
241 private: | 242 private: |
242 Member<ResourceFetcher> m_loader; | 243 Member<ResourceFetcher> m_loader; |
243 bool m_previousState; | 244 bool m_previousState; |
244 }; | 245 }; |
245 | 246 |
246 } // namespace blink | 247 } // namespace blink |
247 | 248 |
248 #endif // ResourceFetcher_h | 249 #endif // ResourceFetcher_h |
OLD | NEW |