| 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 |