| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (C) 1999 Lars Knoll (knoll@kde.org) | 2 * Copyright (C) 1999 Lars Knoll (knoll@kde.org) |
| 3 * (C) 1999 Antti Koivisto (koivisto@kde.org) | 3 * (C) 1999 Antti Koivisto (koivisto@kde.org) |
| 4 * (C) 2001 Dirk Mueller (mueller@kde.org) | 4 * (C) 2001 Dirk Mueller (mueller@kde.org) |
| 5 * (C) 2006 Alexey Proskuryakov (ap@webkit.org) | 5 * (C) 2006 Alexey Proskuryakov (ap@webkit.org) |
| 6 * Copyright (C) 2004, 2005, 2006, 2007, 2008, 2009, 2011, 2012 Apple Inc. All r
ights reserved. | 6 * Copyright (C) 2004, 2005, 2006, 2007, 2008, 2009, 2011, 2012 Apple Inc. All r
ights reserved. |
| 7 * Copyright (C) 2008, 2009 Torch Mobile Inc. All rights reserved. (http://www.t
orchmobile.com/) | 7 * Copyright (C) 2008, 2009 Torch Mobile Inc. All rights reserved. (http://www.t
orchmobile.com/) |
| 8 * Copyright (C) 2008, 2009, 2011, 2012 Google Inc. All rights reserved. | 8 * Copyright (C) 2008, 2009, 2011, 2012 Google Inc. All rights reserved. |
| 9 * Copyright (C) 2010 Nokia Corporation and/or its subsidiary(-ies) | 9 * Copyright (C) 2010 Nokia Corporation and/or its subsidiary(-ies) |
| 10 * Copyright (C) Research In Motion Limited 2010-2011. All rights reserved. | 10 * Copyright (C) Research In Motion Limited 2010-2011. All rights reserved. |
| (...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 47 #include "core/page/InjectedStyleSheets.h" | 47 #include "core/page/InjectedStyleSheets.h" |
| 48 #include "core/page/Page.h" | 48 #include "core/page/Page.h" |
| 49 #include "core/frame/Settings.h" | 49 #include "core/frame/Settings.h" |
| 50 #include "core/svg/SVGStyleElement.h" | 50 #include "core/svg/SVGStyleElement.h" |
| 51 #include "platform/URLPatternMatcher.h" | 51 #include "platform/URLPatternMatcher.h" |
| 52 | 52 |
| 53 namespace WebCore { | 53 namespace WebCore { |
| 54 | 54 |
| 55 using namespace HTMLNames; | 55 using namespace HTMLNames; |
| 56 | 56 |
| 57 static WillBeHeapHashMap<AtomicString, RawPtrWillBeWeakMember<StyleSheetContents
> >& textToSheetCache() | 57 static HashMap<AtomicString, StyleSheetContents*>& textToSheetCache() |
| 58 { | 58 { |
| 59 typedef WillBeHeapHashMap<AtomicString, RawPtrWillBeWeakMember<StyleSheetCon
tents> > TextToSheetCache; | 59 typedef HashMap<AtomicString, StyleSheetContents*> TextToSheetCache; |
| 60 #if ENABLE(OILPAN) | |
| 61 DEFINE_STATIC_LOCAL(Persistent<TextToSheetCache>, cache, (new TextToSheetCac
he)); | |
| 62 return *cache; | |
| 63 #else | |
| 64 DEFINE_STATIC_LOCAL(TextToSheetCache, cache, ()); | 60 DEFINE_STATIC_LOCAL(TextToSheetCache, cache, ()); |
| 65 return cache; | 61 return cache; |
| 66 #endif | |
| 67 } | 62 } |
| 68 | 63 |
| 69 static WillBeHeapHashMap<RawPtrWillBeWeakMember<StyleSheetContents>, AtomicStrin
g>& sheetToTextCache() | 64 static HashMap<StyleSheetContents*, AtomicString>& sheetToTextCache() |
| 70 { | 65 { |
| 71 typedef WillBeHeapHashMap<RawPtrWillBeWeakMember<StyleSheetContents>, Atomic
String> SheetToTextCache; | 66 typedef HashMap<StyleSheetContents*, AtomicString> SheetToTextCache; |
| 72 #if ENABLE(OILPAN) | |
| 73 DEFINE_STATIC_LOCAL(Persistent<SheetToTextCache>, cache, (new SheetToTextCac
he)); | |
| 74 return *cache; | |
| 75 #else | |
| 76 DEFINE_STATIC_LOCAL(SheetToTextCache, cache, ()); | 67 DEFINE_STATIC_LOCAL(SheetToTextCache, cache, ()); |
| 77 return cache; | 68 return cache; |
| 78 #endif | |
| 79 } | 69 } |
| 80 | 70 |
| 81 StyleEngine::StyleEngine(Document& document) | 71 StyleEngine::StyleEngine(Document& document) |
| 82 : m_document(document) | 72 : m_document(document) |
| 83 , m_isMaster(HTMLImport::isMaster(&document)) | 73 , m_isMaster(HTMLImport::isMaster(&document)) |
| 84 , m_pendingStylesheets(0) | 74 , m_pendingStylesheets(0) |
| 85 , m_injectedStyleSheetCacheValid(false) | 75 , m_injectedStyleSheetCacheValid(false) |
| 86 , m_documentStyleSheetCollection(document) | 76 , m_documentStyleSheetCollection(document) |
| 87 , m_documentScopeDirty(true) | 77 , m_documentScopeDirty(true) |
| 88 , m_usesSiblingRules(false) | 78 , m_usesSiblingRules(false) |
| (...skipping 493 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 582 | 572 |
| 583 PassRefPtr<CSSStyleSheet> StyleEngine::createSheet(Element* e, const String& tex
t, TextPosition startPosition, bool createdByParser) | 573 PassRefPtr<CSSStyleSheet> StyleEngine::createSheet(Element* e, const String& tex
t, TextPosition startPosition, bool createdByParser) |
| 584 { | 574 { |
| 585 RefPtr<CSSStyleSheet> styleSheet; | 575 RefPtr<CSSStyleSheet> styleSheet; |
| 586 | 576 |
| 587 e->document().styleEngine()->addPendingSheet(); | 577 e->document().styleEngine()->addPendingSheet(); |
| 588 | 578 |
| 589 if (!e->document().inQuirksMode()) { | 579 if (!e->document().inQuirksMode()) { |
| 590 AtomicString textContent(text); | 580 AtomicString textContent(text); |
| 591 | 581 |
| 592 WillBeHeapHashMap<AtomicString, RawPtrWillBeWeakMember<StyleSheetContent
s> >::AddResult result = textToSheetCache().add(textContent, RawPtrWillBeWeakMem
ber<StyleSheetContents>(nullptr)); | 582 HashMap<AtomicString, StyleSheetContents*>::AddResult result = textToShe
etCache().add(textContent, 0); |
| 593 if (result.isNewEntry || !result.storedValue->value) { | 583 if (result.isNewEntry || !result.storedValue->value) { |
| 594 styleSheet = StyleEngine::parseSheet(e, text, startPosition, created
ByParser); | 584 styleSheet = StyleEngine::parseSheet(e, text, startPosition, created
ByParser); |
| 595 if (result.isNewEntry && styleSheet->contents()->maybeCacheable()) { | 585 if (result.isNewEntry && styleSheet->contents()->maybeCacheable()) { |
| 596 result.storedValue->value = styleSheet->contents(); | 586 result.storedValue->value = styleSheet->contents(); |
| 597 sheetToTextCache().add(styleSheet->contents(), textContent); | 587 sheetToTextCache().add(styleSheet->contents(), textContent); |
| 598 } | 588 } |
| 599 } else { | 589 } else { |
| 600 ASSERT(result.storedValue->value->maybeCacheable()); | 590 ASSERT(result.storedValue->value->maybeCacheable()); |
| 601 styleSheet = CSSStyleSheet::createInline(result.storedValue->value,
e, startPosition); | 591 styleSheet = CSSStyleSheet::createInline(result.storedValue->value,
e, startPosition); |
| 602 } | 592 } |
| (...skipping 10 matching lines...) Expand all Loading... |
| 613 PassRefPtr<CSSStyleSheet> StyleEngine::parseSheet(Element* e, const String& text
, TextPosition startPosition, bool createdByParser) | 603 PassRefPtr<CSSStyleSheet> StyleEngine::parseSheet(Element* e, const String& text
, TextPosition startPosition, bool createdByParser) |
| 614 { | 604 { |
| 615 RefPtr<CSSStyleSheet> styleSheet; | 605 RefPtr<CSSStyleSheet> styleSheet; |
| 616 styleSheet = CSSStyleSheet::createInline(e, KURL(), startPosition, e->docume
nt().inputEncoding()); | 606 styleSheet = CSSStyleSheet::createInline(e, KURL(), startPosition, e->docume
nt().inputEncoding()); |
| 617 styleSheet->contents()->parseStringAtPosition(text, startPosition, createdBy
Parser); | 607 styleSheet->contents()->parseStringAtPosition(text, startPosition, createdBy
Parser); |
| 618 return styleSheet; | 608 return styleSheet; |
| 619 } | 609 } |
| 620 | 610 |
| 621 void StyleEngine::removeSheet(StyleSheetContents* contents) | 611 void StyleEngine::removeSheet(StyleSheetContents* contents) |
| 622 { | 612 { |
| 623 WillBeHeapHashMap<RawPtrWillBeWeakMember<StyleSheetContents>, AtomicString>:
:iterator it = sheetToTextCache().find(contents); | 613 HashMap<StyleSheetContents*, AtomicString>::iterator it = sheetToTextCache()
.find(contents); |
| 624 if (it == sheetToTextCache().end()) | 614 if (it == sheetToTextCache().end()) |
| 625 return; | 615 return; |
| 626 | 616 |
| 627 textToSheetCache().remove(it->value); | 617 textToSheetCache().remove(it->value); |
| 628 sheetToTextCache().remove(contents); | 618 sheetToTextCache().remove(contents); |
| 629 } | 619 } |
| 630 | 620 |
| 631 } | 621 } |
| OLD | NEW |