summaryrefslogtreecommitdiffstats
path: root/Source/WebCore/loader/cache/CachedScript.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'Source/WebCore/loader/cache/CachedScript.cpp')
-rw-r--r--Source/WebCore/loader/cache/CachedScript.cpp16
1 files changed, 13 insertions, 3 deletions
diff --git a/Source/WebCore/loader/cache/CachedScript.cpp b/Source/WebCore/loader/cache/CachedScript.cpp
index 8950ddb..bfd39c5 100644
--- a/Source/WebCore/loader/cache/CachedScript.cpp
+++ b/Source/WebCore/loader/cache/CachedScript.cpp
@@ -55,9 +55,18 @@ CachedScript::~CachedScript()
{
}
+void CachedScript::didAddClient(CachedResourceClient* c)
+{
+ if (m_decodedDataDeletionTimer.isActive())
+ m_decodedDataDeletionTimer.stop();
+
+ CachedResource::didAddClient(c);
+}
+
void CachedScript::allClientsRemoved()
{
- m_decodedDataDeletionTimer.startOneShot(0);
+ if (double interval = memoryCache()->deadDecodedDataDeletionInterval())
+ m_decodedDataDeletionTimer.startOneShot(interval);
}
void CachedScript::setEncoding(const String& chs)
@@ -79,7 +88,6 @@ const String& CachedScript::script()
m_script += m_decoder->flush();
setDecodedSize(m_script.length() * sizeof(UChar));
}
- m_decodedDataDeletionTimer.startOneShot(0);
return m_script;
}
@@ -117,7 +125,9 @@ void CachedScript::destroyDecodedData()
m_script = String();
unsigned extraSize = 0;
#if USE(JSC)
- // FIXME: SourceInfoCache should be wiped out too but not this easily.
+ if (m_sourceProviderCache)
+ m_sourceProviderCache->clear();
+
extraSize = m_sourceProviderCache ? m_sourceProviderCache->byteSize() : 0;
#endif
setDecodedSize(extraSize);