| 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/loader/resource/StyleSheetResourceClient.h" | 29 #include "core/loader/resource/StyleSheetResourceClient.h" |
| 30 #include "platform/RuntimeEnabledFeatures.h" | 30 #include "platform/RuntimeEnabledFeatures.h" |
| 31 #include "platform/SharedBuffer.h" | 31 #include "platform/SharedBuffer.h" |
| 32 #include "platform/loader/fetch/FetchRequest.h" | 32 #include "platform/loader/fetch/FetchRequest.h" |
| 33 #include "platform/loader/fetch/ResourceClientWalker.h" | 33 #include "platform/loader/fetch/ResourceClientWalker.h" |
| 34 #include "platform/loader/fetch/ResourceFetcher.h" | 34 #include "platform/loader/fetch/ResourceFetcher.h" |
| 35 | 35 |
| 36 namespace blink { | 36 namespace blink { |
| 37 | 37 |
| 38 static void applyXSLRequestProperties(ResourceRequest& request) { | 38 static void applyXSLRequestProperties(FetchRequest& request) { |
| 39 request.setRequestContext(WebURLRequest::RequestContextXSLT); | 39 request.setRequestContext(WebURLRequest::RequestContextXSLT); |
| 40 // TODO(japhet): Accept: headers can be set manually on XHRs from script, in | 40 // TODO(japhet): Accept: headers can be set manually on XHRs from script, in |
| 41 // the browser process, and... here. The browser process can't tell the | 41 // the browser process, and... here. The browser process can't tell the |
| 42 // difference between an XSL stylesheet and a CSS stylesheet, so it assumes | 42 // difference between an XSL stylesheet and a CSS stylesheet, so it assumes |
| 43 // stylesheets are all CSS unless they already have an Accept: header set. | 43 // stylesheets are all CSS unless they already have an Accept: header set. |
| 44 // Should we teach the browser process the difference? | 44 // Should we teach the browser process the difference? |
| 45 DEFINE_STATIC_LOCAL(const AtomicString, acceptXSLT, | 45 DEFINE_STATIC_LOCAL(const AtomicString, acceptXSLT, |
| 46 ("text/xml, application/xml, application/xhtml+xml, " | 46 ("text/xml, application/xml, application/xhtml+xml, " |
| 47 "text/xsl, application/rss+xml, application/atom+xml")); | 47 "text/xsl, application/rss+xml, application/atom+xml")); |
| 48 request.setHTTPAccept(acceptXSLT); | 48 request.mutableResourceRequest().setHTTPAccept(acceptXSLT); |
| 49 } | 49 } |
| 50 | 50 |
| 51 XSLStyleSheetResource* XSLStyleSheetResource::fetchSynchronously( | 51 XSLStyleSheetResource* XSLStyleSheetResource::fetchSynchronously( |
| 52 FetchRequest& request, | 52 FetchRequest& request, |
| 53 ResourceFetcher* fetcher) { | 53 ResourceFetcher* fetcher) { |
| 54 applyXSLRequestProperties(request.mutableResourceRequest()); | 54 applyXSLRequestProperties(request); |
| 55 request.makeSynchronous(); | 55 request.makeSynchronous(); |
| 56 XSLStyleSheetResource* resource = toXSLStyleSheetResource( | 56 XSLStyleSheetResource* resource = toXSLStyleSheetResource( |
| 57 fetcher->requestResource(request, XSLStyleSheetResourceFactory())); | 57 fetcher->requestResource(request, XSLStyleSheetResourceFactory())); |
| 58 if (resource && resource->data()) | 58 if (resource && resource->data()) |
| 59 resource->m_sheet = resource->decodedText(); | 59 resource->m_sheet = resource->decodedText(); |
| 60 return resource; | 60 return resource; |
| 61 } | 61 } |
| 62 | 62 |
| 63 XSLStyleSheetResource* XSLStyleSheetResource::fetch(FetchRequest& request, | 63 XSLStyleSheetResource* XSLStyleSheetResource::fetch(FetchRequest& request, |
| 64 ResourceFetcher* fetcher) { | 64 ResourceFetcher* fetcher) { |
| 65 DCHECK(RuntimeEnabledFeatures::xsltEnabled()); | 65 DCHECK(RuntimeEnabledFeatures::xsltEnabled()); |
| 66 applyXSLRequestProperties(request.mutableResourceRequest()); | 66 applyXSLRequestProperties(request); |
| 67 return toXSLStyleSheetResource( | 67 return toXSLStyleSheetResource( |
| 68 fetcher->requestResource(request, XSLStyleSheetResourceFactory())); | 68 fetcher->requestResource(request, XSLStyleSheetResourceFactory())); |
| 69 } | 69 } |
| 70 | 70 |
| 71 XSLStyleSheetResource::XSLStyleSheetResource( | 71 XSLStyleSheetResource::XSLStyleSheetResource( |
| 72 const ResourceRequest& resourceRequest, | 72 const ResourceRequest& resourceRequest, |
| 73 const ResourceLoaderOptions& options, | 73 const ResourceLoaderOptions& options, |
| 74 const String& charset) | 74 const String& charset) |
| 75 : StyleSheetResource(resourceRequest, | 75 : StyleSheetResource(resourceRequest, |
| 76 XSLStyleSheet, | 76 XSLStyleSheet, |
| (...skipping 15 matching lines...) Expand all Loading... |
| 92 m_sheet = decodedText(); | 92 m_sheet = decodedText(); |
| 93 | 93 |
| 94 ResourceClientWalker<StyleSheetResourceClient> w(clients()); | 94 ResourceClientWalker<StyleSheetResourceClient> w(clients()); |
| 95 while (StyleSheetResourceClient* c = w.next()) { | 95 while (StyleSheetResourceClient* c = w.next()) { |
| 96 markClientFinished(c); | 96 markClientFinished(c); |
| 97 c->setXSLStyleSheet(resourceRequest().url(), response().url(), m_sheet); | 97 c->setXSLStyleSheet(resourceRequest().url(), response().url(), m_sheet); |
| 98 } | 98 } |
| 99 } | 99 } |
| 100 | 100 |
| 101 } // namespace blink | 101 } // namespace blink |
| OLD | NEW |