1d02c958d263a314a7265352f039c6b6b98674b8
[WebKit-https.git] / Source / WebCore / page / Settings.cpp
1 /*
2  * Copyright (C) 2006, 2007, 2008, 2009, 2011, 2012 Apple Inc. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  * 1. Redistributions of source code must retain the above copyright
8  *    notice, this list of conditions and the following disclaimer.
9  * 2. Redistributions in binary form must reproduce the above copyright
10  *    notice, this list of conditions and the following disclaimer in the
11  *    documentation and/or other materials provided with the distribution.
12  *
13  * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY
14  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL APPLE COMPUTER, INC. OR
17  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
18  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
19  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
20  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
21  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
23  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
24  */
25
26 #include "config.h"
27 #include "Settings.h"
28
29 #include "BackForwardController.h"
30 #include "CachedResourceLoader.h"
31 #include "CookieStorage.h"
32 #include "DOMTimer.h"
33 #include "Database.h"
34 #include "Document.h"
35 #include "Font.h"
36 #include "FontGenericFamilies.h"
37 #include "FrameTree.h"
38 #include "FrameView.h"
39 #include "HTMLMediaElement.h"
40 #include "HistoryItem.h"
41 #include "InspectorInstrumentation.h"
42 #include "MainFrame.h"
43 #include "Page.h"
44 #include "PageCache.h"
45 #include "StorageMap.h"
46 #include "TextAutosizer.h"
47 #include <limits>
48
49 using namespace std;
50
51 namespace WebCore {
52
53 static void setImageLoadingSettings(Page* page)
54 {
55     for (Frame* frame = &page->mainFrame(); frame; frame = frame->tree().traverseNext()) {
56         frame->document()->cachedResourceLoader()->setImagesEnabled(page->settings().areImagesEnabled());
57         frame->document()->cachedResourceLoader()->setAutoLoadImages(page->settings().loadsImagesAutomatically());
58     }
59 }
60
61 static void invalidateAfterGenericFamilyChange(Page* page)
62 {
63     invalidateFontGlyphsCache();
64     if (page)
65         page->setNeedsRecalcStyleInAllFrames();
66 }
67
68 double Settings::gDefaultMinDOMTimerInterval = 0.010; // 10 milliseconds
69 double Settings::gDefaultDOMTimerAlignmentInterval = 0;
70 double Settings::gHiddenPageDOMTimerAlignmentInterval = 1.0;
71
72 #if USE(SAFARI_THEME)
73 bool Settings::gShouldPaintNativeControls = true;
74 #endif
75
76 #if USE(AVFOUNDATION)
77 bool Settings::gAVFoundationEnabled = false;
78 #endif
79
80 #if PLATFORM(MAC)
81 bool Settings::gQTKitEnabled = true;
82 #endif
83
84 bool Settings::gMockScrollbarsEnabled = false;
85 bool Settings::gUsesOverlayScrollbars = false;
86
87 #if PLATFORM(WIN)
88 bool Settings::gShouldUseHighResolutionTimers = true;
89 #endif
90     
91 bool Settings::gShouldRespectPriorityInCSSAttributeSetters = false;
92 bool Settings::gLowPowerVideoAudioBufferSizeEnabled = false;
93
94 // NOTEs
95 //  1) EditingMacBehavior comprises Tiger, Leopard, SnowLeopard and iOS builds, as well as QtWebKit when built on Mac;
96 //  2) EditingWindowsBehavior comprises Win32 and WinCE builds, as well as QtWebKit and Chromium when built on Windows;
97 //  3) EditingUnixBehavior comprises all unix-based systems, but Darwin/MacOS (and then abusing the terminology);
98 // 99) MacEditingBehavior is used as a fallback.
99 static EditingBehaviorType editingBehaviorTypeForPlatform()
100 {
101     return
102 #if OS(DARWIN)
103     EditingMacBehavior
104 #elif OS(WINDOWS)
105     EditingWindowsBehavior
106 #elif OS(UNIX)
107     EditingUnixBehavior
108 #else
109     // Fallback
110     EditingMacBehavior
111 #endif
112     ;
113 }
114
115 #if PLATFORM(IOS)
116 static const bool defaultFixedPositionCreatesStackingContext = true;
117 static const bool defaultMediaPlaybackAllowsInline = false;
118 static const bool defaultMediaPlaybackRequiresUserGesture = true;
119 static const bool defaultShouldRespectImageOrientation = true;
120 #else
121 static const bool defaultFixedPositionCreatesStackingContext = false;
122 static const bool defaultMediaPlaybackAllowsInline = true;
123 static const bool defaultMediaPlaybackRequiresUserGesture = false;
124 static const bool defaultShouldRespectImageOrientation = false;
125 #endif
126
127 static const double defaultIncrementalRenderingSuppressionTimeoutInSeconds = 5;
128 #if USE(UNIFIED_TEXT_CHECKING)
129 static const bool defaultUnifiedTextCheckerEnabled = true;
130 #else
131 static const bool defaultUnifiedTextCheckerEnabled = false;
132 #endif
133 static const bool defaultSmartInsertDeleteEnabled = true;
134 static const bool defaultSelectTrailingWhitespaceEnabled = false;
135
136 Settings::Settings(Page* page)
137     : m_page(0)
138     , m_mediaTypeOverride("screen")
139     , m_fontGenericFamilies(FontGenericFamilies::create())
140     , m_storageBlockingPolicy(SecurityOrigin::AllowAllStorage)
141 #if ENABLE(TEXT_AUTOSIZING)
142     , m_textAutosizingFontScaleFactor(1)
143 #if HACK_FORCE_TEXT_AUTOSIZING_ON_DESKTOP
144     , m_textAutosizingWindowSizeOverride(320, 480)
145     , m_textAutosizingEnabled(true)
146 #else
147     , m_textAutosizingEnabled(false)
148 #endif
149 #endif
150     SETTINGS_INITIALIZER_LIST
151     , m_screenFontSubstitutionEnabled(shouldEnableScreenFontSubstitutionByDefault())
152     , m_isJavaEnabled(false)
153     , m_isJavaEnabledForLocalFiles(true)
154     , m_loadsImagesAutomatically(false)
155     , m_privateBrowsingEnabled(false)
156     , m_areImagesEnabled(true)
157     , m_arePluginsEnabled(false)
158     , m_isScriptEnabled(false)
159     , m_needsAdobeFrameReloadingQuirk(false)
160     , m_usesPageCache(false)
161     , m_fontRenderingMode(0)
162     , m_isCSSCustomFilterEnabled(false)
163 #if ENABLE(CSS_STICKY_POSITION)
164     , m_cssStickyPositionEnabled(true)
165 #endif
166 #if ENABLE(CSS_VARIABLES)
167     , m_cssVariablesEnabled(false)
168 #endif
169     , m_showTiledScrollingIndicator(false)
170     , m_tiledBackingStoreEnabled(false)
171     , m_dnsPrefetchingEnabled(false)
172 #if ENABLE(TOUCH_EVENTS)
173     , m_touchEventEmulationEnabled(false)
174 #endif
175     , m_scrollingPerformanceLoggingEnabled(false)
176     , m_aggressiveTileRetentionEnabled(false)
177     , m_timeWithoutMouseMovementBeforeHidingControls(3)
178     , m_setImageLoadingSettingsTimer(this, &Settings::imageLoadingSettingsTimerFired)
179 #if ENABLE(HIDDEN_PAGE_DOM_TIMER_THROTTLING)
180     , m_hiddenPageDOMTimerThrottlingEnabled(false)
181 #endif
182 #if ENABLE(PAGE_VISIBILITY_API)
183     , m_hiddenPageCSSAnimationSuspensionEnabled(false)
184 #endif
185 {
186     // A Frame may not have been created yet, so we initialize the AtomicString
187     // hash before trying to use it.
188     AtomicString::init();
189     initializeDefaultFontFamilies();
190     m_page = page; // Page is not yet fully initialized wen constructing Settings, so keeping m_page null over initializeDefaultFontFamilies() call.
191 }
192
193 Settings::~Settings()
194 {
195 }
196
197 PassRefPtr<Settings> Settings::create(Page* page)
198 {
199     return adoptRef(new Settings(page));
200 }
201
202 SETTINGS_SETTER_BODIES
203
204 void Settings::setHiddenPageDOMTimerAlignmentInterval(double hiddenPageDOMTimerAlignmentinterval)
205 {
206     gHiddenPageDOMTimerAlignmentInterval = hiddenPageDOMTimerAlignmentinterval;
207 }
208
209 double Settings::hiddenPageDOMTimerAlignmentInterval()
210 {
211     return gHiddenPageDOMTimerAlignmentInterval;
212 }
213
214 #if !PLATFORM(MAC)
215 bool Settings::shouldEnableScreenFontSubstitutionByDefault()
216 {
217     return true;
218 }
219 #endif
220
221 #if !PLATFORM(MAC) && !PLATFORM(BLACKBERRY)
222 void Settings::initializeDefaultFontFamilies()
223 {
224     // Other platforms can set up fonts from a client, but on Mac, we want it in WebCore to share code between WebKit1 and WebKit2.
225 }
226 #endif
227
228 const AtomicString& Settings::standardFontFamily(UScriptCode script) const
229 {
230     return m_fontGenericFamilies->standardFontFamily(script);
231 }
232
233 void Settings::setStandardFontFamily(const AtomicString& family, UScriptCode script)
234 {
235     bool changes = m_fontGenericFamilies->setStandardFontFamily(family, script);
236     if (changes)
237         invalidateAfterGenericFamilyChange(m_page);
238 }
239
240 const AtomicString& Settings::fixedFontFamily(UScriptCode script) const
241 {
242     return m_fontGenericFamilies->fixedFontFamily(script);
243 }
244
245 void Settings::setFixedFontFamily(const AtomicString& family, UScriptCode script)
246 {
247     bool changes = m_fontGenericFamilies->setFixedFontFamily(family, script);
248     if (changes)
249         invalidateAfterGenericFamilyChange(m_page);
250 }
251
252 const AtomicString& Settings::serifFontFamily(UScriptCode script) const
253 {
254     return m_fontGenericFamilies->serifFontFamily(script);
255 }
256
257 void Settings::setSerifFontFamily(const AtomicString& family, UScriptCode script)
258 {
259     bool changes = m_fontGenericFamilies->setSerifFontFamily(family, script);
260     if (changes)
261         invalidateAfterGenericFamilyChange(m_page);
262 }
263
264 const AtomicString& Settings::sansSerifFontFamily(UScriptCode script) const
265 {
266     return m_fontGenericFamilies->sansSerifFontFamily(script);
267 }
268
269 void Settings::setSansSerifFontFamily(const AtomicString& family, UScriptCode script)
270 {
271     bool changes = m_fontGenericFamilies->setSansSerifFontFamily(family, script);
272     if (changes)
273         invalidateAfterGenericFamilyChange(m_page);
274 }
275
276 const AtomicString& Settings::cursiveFontFamily(UScriptCode script) const
277 {
278     return m_fontGenericFamilies->cursiveFontFamily(script);
279 }
280
281 void Settings::setCursiveFontFamily(const AtomicString& family, UScriptCode script)
282 {
283     bool changes = m_fontGenericFamilies->setCursiveFontFamily(family, script);
284     if (changes)
285         invalidateAfterGenericFamilyChange(m_page);
286 }
287
288 const AtomicString& Settings::fantasyFontFamily(UScriptCode script) const
289 {
290     return m_fontGenericFamilies->fantasyFontFamily(script);
291 }
292
293 void Settings::setFantasyFontFamily(const AtomicString& family, UScriptCode script)
294 {
295     bool changes = m_fontGenericFamilies->setFantasyFontFamily(family, script);
296     if (changes)
297         invalidateAfterGenericFamilyChange(m_page);
298 }
299
300 const AtomicString& Settings::pictographFontFamily(UScriptCode script) const
301 {
302     return m_fontGenericFamilies->pictographFontFamily(script);
303 }
304
305 void Settings::setPictographFontFamily(const AtomicString& family, UScriptCode script)
306 {
307     bool changes = m_fontGenericFamilies->setPictographFontFamily(family, script);
308     if (changes)
309         invalidateAfterGenericFamilyChange(m_page);
310 }
311
312 #if ENABLE(TEXT_AUTOSIZING)
313 void Settings::setTextAutosizingEnabled(bool textAutosizingEnabled)
314 {
315     if (m_textAutosizingEnabled == textAutosizingEnabled)
316         return;
317
318     m_textAutosizingEnabled = textAutosizingEnabled;
319     m_page->setNeedsRecalcStyleInAllFrames();
320 }
321
322 void Settings::setTextAutosizingWindowSizeOverride(const IntSize& textAutosizingWindowSizeOverride)
323 {
324     if (m_textAutosizingWindowSizeOverride == textAutosizingWindowSizeOverride)
325         return;
326
327     m_textAutosizingWindowSizeOverride = textAutosizingWindowSizeOverride;
328     m_page->setNeedsRecalcStyleInAllFrames();
329 }
330
331 void Settings::setTextAutosizingFontScaleFactor(float fontScaleFactor)
332 {
333     m_textAutosizingFontScaleFactor = fontScaleFactor;
334
335     // FIXME: I wonder if this needs to traverse frames like in WebViewImpl::resize, or whether there is only one document per Settings instance?
336     for (Frame* frame = m_page->mainFrame(); frame; frame = frame->tree().traverseNext())
337         frame->document()->textAutosizer()->recalculateMultipliers();
338
339     m_page->setNeedsRecalcStyleInAllFrames();
340 }
341
342 #endif
343
344 void Settings::setMediaTypeOverride(const String& mediaTypeOverride)
345 {
346     if (m_mediaTypeOverride == mediaTypeOverride)
347         return;
348
349     m_mediaTypeOverride = mediaTypeOverride;
350
351     FrameView* view = m_page->mainFrame().view();
352     ASSERT(view);
353
354     view->setMediaType(mediaTypeOverride);
355     m_page->setNeedsRecalcStyleInAllFrames();
356 }
357
358 void Settings::setLoadsImagesAutomatically(bool loadsImagesAutomatically)
359 {
360     m_loadsImagesAutomatically = loadsImagesAutomatically;
361     
362     // Changing this setting to true might immediately start new loads for images that had previously had loading disabled.
363     // If this happens while a WebView is being dealloc'ed, and we don't know the WebView is being dealloc'ed, these new loads
364     // can cause crashes downstream when the WebView memory has actually been free'd.
365     // One example where this can happen is in Mac apps that subclass WebView then do work in their overridden dealloc methods.
366     // Starting these loads synchronously is not important.  By putting it on a 0-delay, properly closing the Page cancels them
367     // before they have a chance to really start.
368     // See http://webkit.org/b/60572 for more discussion.
369     m_setImageLoadingSettingsTimer.startOneShot(0);
370 }
371
372 void Settings::imageLoadingSettingsTimerFired(Timer<Settings>*)
373 {
374     setImageLoadingSettings(m_page);
375 }
376
377 void Settings::setScriptEnabled(bool isScriptEnabled)
378 {
379     m_isScriptEnabled = isScriptEnabled;
380     InspectorInstrumentation::scriptsEnabled(m_page, m_isScriptEnabled);
381 }
382
383 void Settings::setJavaEnabled(bool isJavaEnabled)
384 {
385     m_isJavaEnabled = isJavaEnabled;
386 }
387
388 void Settings::setJavaEnabledForLocalFiles(bool isJavaEnabledForLocalFiles)
389 {
390     m_isJavaEnabledForLocalFiles = isJavaEnabledForLocalFiles;
391 }
392
393 void Settings::setImagesEnabled(bool areImagesEnabled)
394 {
395     m_areImagesEnabled = areImagesEnabled;
396
397     // See comment in setLoadsImagesAutomatically.
398     m_setImageLoadingSettingsTimer.startOneShot(0);
399 }
400
401 void Settings::setPluginsEnabled(bool arePluginsEnabled)
402 {
403     if (m_arePluginsEnabled == arePluginsEnabled)
404         return;
405
406     m_arePluginsEnabled = arePluginsEnabled;
407     Page::refreshPlugins(false);
408 }
409
410 void Settings::setPrivateBrowsingEnabled(bool privateBrowsingEnabled)
411 {
412     if (m_privateBrowsingEnabled == privateBrowsingEnabled)
413         return;
414
415     m_privateBrowsingEnabled = privateBrowsingEnabled;
416     m_page->privateBrowsingStateChanged();
417 }
418
419 void Settings::setUserStyleSheetLocation(const URL& userStyleSheetLocation)
420 {
421     if (m_userStyleSheetLocation == userStyleSheetLocation)
422         return;
423
424     m_userStyleSheetLocation = userStyleSheetLocation;
425
426     m_page->userStyleSheetLocationChanged();
427 }
428
429 // FIXME: This quirk is needed because of Radar 4674537 and 5211271. We need to phase it out once Adobe
430 // can fix the bug from their end.
431 void Settings::setNeedsAdobeFrameReloadingQuirk(bool shouldNotReloadIFramesForUnchangedSRC)
432 {
433     m_needsAdobeFrameReloadingQuirk = shouldNotReloadIFramesForUnchangedSRC;
434 }
435
436 void Settings::setDefaultMinDOMTimerInterval(double interval)
437 {
438     gDefaultMinDOMTimerInterval = interval;
439 }
440
441 double Settings::defaultMinDOMTimerInterval()
442 {
443     return gDefaultMinDOMTimerInterval;
444 }
445
446 void Settings::setMinDOMTimerInterval(double interval)
447 {
448     m_page->setMinimumTimerInterval(interval);
449 }
450
451 double Settings::minDOMTimerInterval()
452 {
453     return m_page->minimumTimerInterval();
454 }
455
456 void Settings::setDefaultDOMTimerAlignmentInterval(double interval)
457 {
458     gDefaultDOMTimerAlignmentInterval = interval;
459 }
460
461 double Settings::defaultDOMTimerAlignmentInterval()
462 {
463     return gDefaultDOMTimerAlignmentInterval;
464 }
465
466 void Settings::setDOMTimerAlignmentInterval(double interval)
467 {
468     m_page->setTimerAlignmentInterval(interval);
469 }
470
471 double Settings::domTimerAlignmentInterval() const
472 {
473     return m_page->timerAlignmentInterval();
474 }
475
476 void Settings::setUsesPageCache(bool usesPageCache)
477 {
478     if (m_usesPageCache == usesPageCache)
479         return;
480         
481     m_usesPageCache = usesPageCache;
482     if (!m_usesPageCache) {
483         int first = -m_page->backForward().backCount();
484         int last = m_page->backForward().forwardCount();
485         for (int i = first; i <= last; i++)
486             pageCache()->remove(m_page->backForward().itemAtIndex(i));
487     }
488 }
489
490 void Settings::setScreenFontSubstitutionEnabled(bool enabled)
491 {
492     if (m_screenFontSubstitutionEnabled == enabled)
493         return;
494     m_screenFontSubstitutionEnabled = enabled;
495     m_page->setNeedsRecalcStyleInAllFrames();
496 }
497
498 void Settings::setFontRenderingMode(FontRenderingMode mode)
499 {
500     if (fontRenderingMode() == mode)
501         return;
502     m_fontRenderingMode = mode;
503     m_page->setNeedsRecalcStyleInAllFrames();
504 }
505
506 FontRenderingMode Settings::fontRenderingMode() const
507 {
508     return static_cast<FontRenderingMode>(m_fontRenderingMode);
509 }
510
511 #if USE(SAFARI_THEME)
512 void Settings::setShouldPaintNativeControls(bool shouldPaintNativeControls)
513 {
514     gShouldPaintNativeControls = shouldPaintNativeControls;
515 }
516 #endif
517
518 void Settings::setDNSPrefetchingEnabled(bool dnsPrefetchingEnabled)
519 {
520     if (m_dnsPrefetchingEnabled == dnsPrefetchingEnabled)
521         return;
522
523     m_dnsPrefetchingEnabled = dnsPrefetchingEnabled;
524     m_page->dnsPrefetchingStateChanged();
525 }
526
527 void Settings::setShowTiledScrollingIndicator(bool enabled)
528 {
529     if (m_showTiledScrollingIndicator == enabled)
530         return;
531         
532     m_showTiledScrollingIndicator = enabled;
533 }
534
535 #if PLATFORM(WIN)
536 void Settings::setShouldUseHighResolutionTimers(bool shouldUseHighResolutionTimers)
537 {
538     gShouldUseHighResolutionTimers = shouldUseHighResolutionTimers;
539 }
540 #endif
541
542 void Settings::setStorageBlockingPolicy(SecurityOrigin::StorageBlockingPolicy enabled)
543 {
544     if (m_storageBlockingPolicy == enabled)
545         return;
546
547     m_storageBlockingPolicy = enabled;
548     m_page->storageBlockingStateChanged();
549 }
550
551 void Settings::setTiledBackingStoreEnabled(bool enabled)
552 {
553     m_tiledBackingStoreEnabled = enabled;
554 #if USE(TILED_BACKING_STORE)
555     m_page->mainFrame().setTiledBackingStoreEnabled(enabled);
556 #endif
557 }
558
559 #if USE(AVFOUNDATION)
560 void Settings::setAVFoundationEnabled(bool enabled)
561 {
562     if (gAVFoundationEnabled == enabled)
563         return;
564
565     gAVFoundationEnabled = enabled;
566     HTMLMediaElement::resetMediaEngines();
567 }
568 #endif
569
570 #if PLATFORM(MAC)
571 void Settings::setQTKitEnabled(bool enabled)
572 {
573     if (gQTKitEnabled == enabled)
574         return;
575
576     gQTKitEnabled = enabled;
577     HTMLMediaElement::resetMediaEngines();
578 }
579 #endif
580
581 void Settings::setScrollingPerformanceLoggingEnabled(bool enabled)
582 {
583     m_scrollingPerformanceLoggingEnabled = enabled;
584
585     if (m_page->mainFrame().view())
586         m_page->mainFrame().view()->setScrollingPerformanceLoggingEnabled(enabled);
587 }
588     
589 void Settings::setAggressiveTileRetentionEnabled(bool enabled)
590 {
591     m_aggressiveTileRetentionEnabled = enabled;
592 }
593
594 void Settings::setMockScrollbarsEnabled(bool flag)
595 {
596     gMockScrollbarsEnabled = flag;
597 }
598
599 bool Settings::mockScrollbarsEnabled()
600 {
601     return gMockScrollbarsEnabled;
602 }
603
604 void Settings::setUsesOverlayScrollbars(bool flag)
605 {
606     gUsesOverlayScrollbars = flag;
607 }
608
609 bool Settings::usesOverlayScrollbars()
610 {
611     return gUsesOverlayScrollbars;
612 }
613
614 void Settings::setShouldRespectPriorityInCSSAttributeSetters(bool flag)
615 {
616     gShouldRespectPriorityInCSSAttributeSetters = flag;
617 }
618
619 bool Settings::shouldRespectPriorityInCSSAttributeSetters()
620 {
621     return gShouldRespectPriorityInCSSAttributeSetters;
622 }
623
624 #if ENABLE(HIDDEN_PAGE_DOM_TIMER_THROTTLING)
625 void Settings::setHiddenPageDOMTimerThrottlingEnabled(bool flag)
626 {
627     if (m_hiddenPageDOMTimerThrottlingEnabled == flag)
628         return;
629     m_hiddenPageDOMTimerThrottlingEnabled = flag;
630     m_page->hiddenPageDOMTimerThrottlingStateChanged();
631 }
632 #endif
633
634 #if ENABLE(PAGE_VISIBILITY_API)
635 void Settings::setHiddenPageCSSAnimationSuspensionEnabled(bool flag)
636 {
637     if (m_hiddenPageCSSAnimationSuspensionEnabled == flag)
638         return;
639     m_hiddenPageCSSAnimationSuspensionEnabled = flag;
640     m_page->hiddenPageCSSAnimationSuspensionStateChanged();
641 }
642 #endif
643
644 void Settings::setLowPowerVideoAudioBufferSizeEnabled(bool flag)
645 {
646     gLowPowerVideoAudioBufferSizeEnabled = flag;
647 }
648
649 } // namespace WebCore