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) 2002 Waldo Bastian (bastian@kde.org) | 4 Copyright (C) 2002 Waldo Bastian (bastian@kde.org) |
5 Copyright (C) 2006 Samuel Weinig (sam.weinig@gmail.com) | 5 Copyright (C) 2006 Samuel Weinig (sam.weinig@gmail.com) |
6 Copyright (C) 2004, 2005, 2006, 2007, 2008 Apple Inc. All rights reserved. | 6 Copyright (C) 2004, 2005, 2006, 2007, 2008 Apple Inc. All rights reserved. |
7 | 7 |
8 This library is free software; you can redistribute it and/or | 8 This library is free software; you can redistribute it and/or |
9 modify it under the terms of the GNU Library General Public | 9 modify it under the terms of the GNU Library General Public |
10 License as published by the Free Software Foundation; either | 10 License as published by the Free Software Foundation; either |
(...skipping 17 matching lines...) Expand all Loading... |
28 | 28 |
29 #include "core/fetch/FetchRequest.h" | 29 #include "core/fetch/FetchRequest.h" |
30 #include "core/fetch/ResourceClientOrObserverWalker.h" | 30 #include "core/fetch/ResourceClientOrObserverWalker.h" |
31 #include "core/fetch/ResourceFetcher.h" | 31 #include "core/fetch/ResourceFetcher.h" |
32 #include "core/fetch/StyleSheetResourceClient.h" | 32 #include "core/fetch/StyleSheetResourceClient.h" |
33 #include "platform/RuntimeEnabledFeatures.h" | 33 #include "platform/RuntimeEnabledFeatures.h" |
34 #include "platform/SharedBuffer.h" | 34 #include "platform/SharedBuffer.h" |
35 | 35 |
36 namespace blink { | 36 namespace blink { |
37 | 37 |
| 38 static void applyXSLRequestProperties(ResourceRequest& request) |
| 39 { |
| 40 request.setRequestContext(WebURLRequest::RequestContextXSLT); |
| 41 // TODO(japhet): Accept: headers can be set manually on XHRs from script, |
| 42 // in the browser process, and... here. The browser process can't tell the |
| 43 // difference between an XSL stylesheet and a CSS stylesheet, so it assumes |
| 44 // stylesheets are all CSS unless they already have an Accept: header set. |
| 45 // Should we teach the browser process the difference? |
| 46 DEFINE_STATIC_LOCAL(const AtomicString, acceptXSLT, ("text/xml, application/
xml, application/xhtml+xml, text/xsl, application/rss+xml, application/atom+xml"
)); |
| 47 request.setHTTPAccept(acceptXSLT); |
| 48 } |
| 49 |
38 XSLStyleSheetResource* XSLStyleSheetResource::fetchSynchronously(FetchRequest& r
equest, ResourceFetcher* fetcher) | 50 XSLStyleSheetResource* XSLStyleSheetResource::fetchSynchronously(FetchRequest& r
equest, ResourceFetcher* fetcher) |
39 { | 51 { |
| 52 applyXSLRequestProperties(request.mutableResourceRequest()); |
40 request.mutableResourceRequest().setTimeoutInterval(10); | 53 request.mutableResourceRequest().setTimeoutInterval(10); |
41 request.mutableResourceRequest().setRequestContext(WebURLRequest::RequestCon
textXSLT); | |
42 ResourceLoaderOptions options(request.options()); | 54 ResourceLoaderOptions options(request.options()); |
43 options.synchronousPolicy = RequestSynchronously; | 55 options.synchronousPolicy = RequestSynchronously; |
44 request.setOptions(options); | 56 request.setOptions(options); |
45 XSLStyleSheetResource* resource = toXSLStyleSheetResource(fetcher->requestRe
source(request, XSLStyleSheetResourceFactory())); | 57 XSLStyleSheetResource* resource = toXSLStyleSheetResource(fetcher->requestRe
source(request, XSLStyleSheetResourceFactory())); |
46 if (resource && resource->m_data) | 58 if (resource && resource->m_data) |
47 resource->m_sheet = resource->decodedText(); | 59 resource->m_sheet = resource->decodedText(); |
48 return resource; | 60 return resource; |
49 } | 61 } |
50 | 62 |
51 XSLStyleSheetResource* XSLStyleSheetResource::fetch(FetchRequest& request, Resou
rceFetcher* fetcher) | 63 XSLStyleSheetResource* XSLStyleSheetResource::fetch(FetchRequest& request, Resou
rceFetcher* fetcher) |
52 { | 64 { |
53 ASSERT(RuntimeEnabledFeatures::xsltEnabled()); | 65 ASSERT(RuntimeEnabledFeatures::xsltEnabled()); |
54 request.mutableResourceRequest().setRequestContext(WebURLRequest::RequestCon
textXSLT); | 66 applyXSLRequestProperties(request.mutableResourceRequest()); |
55 return toXSLStyleSheetResource(fetcher->requestResource(request, XSLStyleShe
etResourceFactory())); | 67 return toXSLStyleSheetResource(fetcher->requestResource(request, XSLStyleShe
etResourceFactory())); |
56 } | 68 } |
57 | 69 |
58 XSLStyleSheetResource::XSLStyleSheetResource(const ResourceRequest& resourceRequ
est, const ResourceLoaderOptions& options, const String& charset) | 70 XSLStyleSheetResource::XSLStyleSheetResource(const ResourceRequest& resourceRequ
est, const ResourceLoaderOptions& options, const String& charset) |
59 : StyleSheetResource(resourceRequest, XSLStyleSheet, options, "text/xsl", ch
arset) | 71 : StyleSheetResource(resourceRequest, XSLStyleSheet, options, "text/xsl", ch
arset) |
60 { | 72 { |
61 ASSERT(RuntimeEnabledFeatures::xsltEnabled()); | |
62 DEFINE_STATIC_LOCAL(const AtomicString, acceptXSLT, ("text/xml, application/
xml, application/xhtml+xml, text/xsl, application/rss+xml, application/atom+xml"
)); | |
63 | |
64 // It's XML we want. | |
65 // FIXME: This should accept more general xml formats */*+xml, image/svg+xml
for example. | |
66 setAccept(acceptXSLT); | |
67 } | 73 } |
68 | 74 |
69 void XSLStyleSheetResource::didAddClient(ResourceClient* c) | 75 void XSLStyleSheetResource::didAddClient(ResourceClient* c) |
70 { | 76 { |
71 ASSERT(StyleSheetResourceClient::isExpectedType(c)); | 77 ASSERT(StyleSheetResourceClient::isExpectedType(c)); |
72 Resource::didAddClient(c); | 78 Resource::didAddClient(c); |
73 if (!isLoading()) | 79 if (!isLoading()) |
74 static_cast<StyleSheetResourceClient*>(c)->setXSLStyleSheet(m_resourceRe
quest.url(), m_response.url(), m_sheet); | 80 static_cast<StyleSheetResourceClient*>(c)->setXSLStyleSheet(m_resourceRe
quest.url(), m_response.url(), m_sheet); |
75 } | 81 } |
76 | 82 |
77 void XSLStyleSheetResource::checkNotify() | 83 void XSLStyleSheetResource::checkNotify() |
78 { | 84 { |
79 if (m_data.get()) | 85 if (m_data.get()) |
80 m_sheet = decodedText(); | 86 m_sheet = decodedText(); |
81 | 87 |
82 ResourceClientWalker<StyleSheetResourceClient> w(m_clients); | 88 ResourceClientWalker<StyleSheetResourceClient> w(m_clients); |
83 while (StyleSheetResourceClient* c = w.next()) | 89 while (StyleSheetResourceClient* c = w.next()) |
84 c->setXSLStyleSheet(m_resourceRequest.url(), m_response.url(), m_sheet); | 90 c->setXSLStyleSheet(m_resourceRequest.url(), m_response.url(), m_sheet); |
85 } | 91 } |
86 | 92 |
87 } // namespace blink | 93 } // namespace blink |
OLD | NEW |