// Copyright (c) 2013 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef CONTENT_RENDERER_INTERNAL_DOCUMENT_STATE_DATA_H_ #define CONTENT_RENDERER_INTERNAL_DOCUMENT_STATE_DATA_H_ #include #include "base/memory/scoped_ptr.h" #include "base/supports_user_data.h" #include "third_party/WebKit/public/platform/WebReferrerPolicy.h" #include "third_party/WebKit/public/platform/WebURLRequest.h" #include "url/gurl.h" namespace blink { class WebDataSource; } namespace content { class AltErrorPageResourceFetcher; class DocumentState; // Stores internal state per WebDataSource. class InternalDocumentStateData : public base::SupportsUserData::Data { public: InternalDocumentStateData(); static InternalDocumentStateData* FromDataSource(blink::WebDataSource* ds); static InternalDocumentStateData* FromDocumentState(DocumentState* ds); // Set to true once RenderViewImpl::didFirstVisuallyNonEmptyLayout() is // invoked. bool did_first_visually_non_empty_layout() const { return did_first_visually_non_empty_layout_; } void set_did_first_visually_non_empty_layout(bool value) { did_first_visually_non_empty_layout_ = value; } // Set to true once RenderViewImpl::DidFlushPaint() is inovked after // RenderViewImpl::didFirstVisuallyNonEmptyLayout(). In other words after the // page has painted something. bool did_first_visually_non_empty_paint() const { return did_first_visually_non_empty_paint_; } void set_did_first_visually_non_empty_paint(bool value) { did_first_visually_non_empty_paint_ = value; } int http_status_code() const { return http_status_code_; } void set_http_status_code(int http_status_code) { http_status_code_ = http_status_code; } const GURL& searchable_form_url() const { return searchable_form_url_; } void set_searchable_form_url(const GURL& url) { searchable_form_url_ = url; } const std::string& searchable_form_encoding() const { return searchable_form_encoding_; } void set_searchable_form_encoding(const std::string& encoding) { searchable_form_encoding_ = encoding; } // True if an error page should be used, if the http status code also // indicates an error. bool use_error_page() const { return use_error_page_; } void set_use_error_page(bool use_error_page) { use_error_page_ = use_error_page; } // True if the user agent was overridden for this page. bool is_overriding_user_agent() const { return is_overriding_user_agent_; } void set_is_overriding_user_agent(bool state) { is_overriding_user_agent_ = state; } // True if we have to reset the scroll and scale state of the page // after the provisional load has been committed. bool must_reset_scroll_and_scale_state() const { return must_reset_scroll_and_scale_state_; } void set_must_reset_scroll_and_scale_state(bool state) { must_reset_scroll_and_scale_state_ = state; } // Sets the cache policy. The cache policy is only used if explicitly set and // by default is not set. You can mark a NavigationState as not having a cache // state by way of clear_cache_policy_override. void set_cache_policy_override( blink::WebURLRequest::CachePolicy cache_policy) { cache_policy_override_ = cache_policy; cache_policy_override_set_ = true; } blink::WebURLRequest::CachePolicy cache_policy_override() const { return cache_policy_override_; } void clear_cache_policy_override() { cache_policy_override_set_ = false; cache_policy_override_ = blink::WebURLRequest::UseProtocolCachePolicy; } bool is_cache_policy_override_set() const { return cache_policy_override_set_; } // Sets the referrer policy to use. This is only used for browser initiated // navigations, otherwise, the referrer policy is defined by the frame's // document. blink::WebReferrerPolicy referrer_policy() const { return referrer_policy_; } void set_referrer_policy(blink::WebReferrerPolicy referrer_policy) { referrer_policy_ = referrer_policy; referrer_policy_set_ = true; } void clear_referrer_policy() { referrer_policy_ = blink::WebReferrerPolicyDefault; referrer_policy_set_ = false; } bool is_referrer_policy_set() const { return referrer_policy_set_; } AltErrorPageResourceFetcher* alt_error_page_fetcher() const { return alt_error_page_fetcher_.get(); } void set_alt_error_page_fetcher(AltErrorPageResourceFetcher* f); protected: virtual ~InternalDocumentStateData(); private: bool did_first_visually_non_empty_layout_; bool did_first_visually_non_empty_paint_; int http_status_code_; GURL searchable_form_url_; std::string searchable_form_encoding_; bool use_error_page_; bool is_overriding_user_agent_; bool must_reset_scroll_and_scale_state_; bool cache_policy_override_set_; blink::WebURLRequest::CachePolicy cache_policy_override_; bool referrer_policy_set_; blink::WebReferrerPolicy referrer_policy_; scoped_ptr alt_error_page_fetcher_; DISALLOW_COPY_AND_ASSIGN(InternalDocumentStateData); }; } // namespace content #endif // CONTENT_RENDERER_INTERNAL_DOCUMENT_STATE_DATA_H_