/* * Copyright (C) 2008, 2009 Apple Inc. All Rights Reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #ifndef DOMApplicationCache_h #define DOMApplicationCache_h #if ENABLE(OFFLINE_WEB_APPLICATIONS) #include "AtomicStringHash.h" #include "EventTarget.h" #include "EventListener.h" #include #include #include #include namespace WebCore { class ApplicationCache; class AtomicStringImpl; class DOMStringList; class Frame; class KURL; class String; class DOMApplicationCache : public RefCounted, public EventTarget { public: static PassRefPtr create(Frame* frame) { return adoptRef(new DOMApplicationCache(frame)); } void disconnectFrame(); enum Status { UNCACHED = 0, IDLE = 1, CHECKING = 2, DOWNLOADING = 3, UPDATEREADY = 4, OBSOLETE = 5 }; unsigned short status() const; void update(ExceptionCode&); void swapCache(ExceptionCode&); PassRefPtr items(); bool hasItem(const KURL&, ExceptionCode&); void add(const KURL&, ExceptionCode&); void remove(const KURL&, ExceptionCode&); virtual void addEventListener(const AtomicString& eventType, PassRefPtr, bool useCapture); virtual void removeEventListener(const AtomicString& eventType, EventListener*, bool useCapture); virtual bool dispatchEvent(PassRefPtr, ExceptionCode&); typedef Vector > ListenerVector; typedef HashMap EventListenersMap; EventListenersMap& eventListeners() { return m_eventListeners; } using RefCounted::ref; using RefCounted::deref; void setOnchecking(PassRefPtr eventListener) { m_onCheckingListener = eventListener; } EventListener* onchecking() const { return m_onCheckingListener.get(); } void setOnerror(PassRefPtr eventListener) { m_onErrorListener = eventListener; } EventListener* onerror() const { return m_onErrorListener.get(); } void setOnnoupdate(PassRefPtr eventListener) { m_onNoUpdateListener = eventListener; } EventListener* onnoupdate() const { return m_onNoUpdateListener.get(); } void setOndownloading(PassRefPtr eventListener) { m_onDownloadingListener = eventListener; } EventListener* ondownloading() const { return m_onDownloadingListener.get(); } void setOnprogress(PassRefPtr eventListener) { m_onProgressListener = eventListener; } EventListener* onprogress() const { return m_onProgressListener.get(); } void setOnupdateready(PassRefPtr eventListener) { m_onUpdateReadyListener = eventListener; } EventListener* onupdateready() const { return m_onUpdateReadyListener.get(); } void setOncached(PassRefPtr eventListener) { m_onCachedListener = eventListener; } EventListener* oncached() const { return m_onCachedListener.get(); } void setOnobsolete(PassRefPtr eventListener) { m_onObsoleteListener = eventListener; } EventListener* onobsolete() const { return m_onObsoleteListener.get(); } virtual ScriptExecutionContext* scriptExecutionContext() const; DOMApplicationCache* toDOMApplicationCache() { return this; } void callCheckingListener(); void callErrorListener(); void callNoUpdateListener(); void callDownloadingListener(); void callProgressListener(); void callUpdateReadyListener(); void callCachedListener(); void callObsoleteListener(); #if USE(V8) EventListener* getAttributeEventListener(const AtomicString& eventType); void setAttributeEventListener(const AtomicString& eventType, PassRefPtr listener); void clearAttributeEventListener(const AtomicString& eventType); #endif private: DOMApplicationCache(Frame*); void callListener(const AtomicString& eventType, EventListener*); virtual void refEventTarget() { ref(); } virtual void derefEventTarget() { deref(); } ApplicationCache* associatedCache() const; bool swapCache(); #if USE(V8) RefPtr* getAttributeEventListenerStorage(const AtomicString& eventType); #endif RefPtr m_onCheckingListener; RefPtr m_onErrorListener; RefPtr m_onNoUpdateListener; RefPtr m_onDownloadingListener; RefPtr m_onProgressListener; RefPtr m_onUpdateReadyListener; RefPtr m_onCachedListener; RefPtr m_onObsoleteListener; EventListenersMap m_eventListeners; Frame* m_frame; }; } // namespace WebCore #endif // ENABLE(OFFLINE_WEB_APPLICATIONS) #endif // DOMApplicationCache_h