diff options
Diffstat (limited to 'WebCore')
-rw-r--r-- | WebCore/Android.derived.jscbindings.mk | 2 | ||||
-rw-r--r-- | WebCore/Android.derived.v8bindings.mk | 2 | ||||
-rw-r--r-- | WebCore/Android.jscbindings.mk | 1 | ||||
-rw-r--r-- | WebCore/Android.v8bindings.mk | 1 | ||||
-rw-r--r-- | WebCore/bindings/js/JSCustomApplicationInstalledCallback.cpp | 56 | ||||
-rw-r--r-- | WebCore/bindings/js/JSCustomApplicationInstalledCallback.h | 56 | ||||
-rw-r--r-- | WebCore/bindings/js/JSNavigatorCustom.cpp | 37 | ||||
-rw-r--r-- | WebCore/bindings/v8/V8Proxy.cpp | 10 | ||||
-rw-r--r-- | WebCore/bindings/v8/custom/V8CustomApplicationInstalledCallback.cpp | 70 | ||||
-rw-r--r-- | WebCore/bindings/v8/custom/V8CustomApplicationInstalledCallback.h | 61 | ||||
-rw-r--r-- | WebCore/bindings/v8/custom/V8NavigatorCustom.cpp | 48 | ||||
-rw-r--r-- | WebCore/config.h | 2 | ||||
-rw-r--r-- | WebCore/page/ApplicationInstalledCallback.h | 45 | ||||
-rw-r--r-- | WebCore/page/Navigator.cpp | 16 | ||||
-rw-r--r-- | WebCore/page/Navigator.h | 12 | ||||
-rw-r--r-- | WebCore/page/Navigator.idl | 5 | ||||
-rw-r--r-- | WebCore/platform/android/GeolocationServiceAndroid.cpp | 4 | ||||
-rw-r--r-- | WebCore/platform/graphics/android/FontDataAndroid.cpp | 19 |
18 files changed, 411 insertions, 36 deletions
diff --git a/WebCore/Android.derived.jscbindings.mk b/WebCore/Android.derived.jscbindings.mk index 067aa0c..4ba1874 100644 --- a/WebCore/Android.derived.jscbindings.mk +++ b/WebCore/Android.derived.jscbindings.mk @@ -49,7 +49,7 @@ js_binding_scripts := $(addprefix $(LOCAL_PATH)/,\ bindings/scripts/generate-bindings.pl \ ) -FEATURE_DEFINES := ENABLE_ORIENTATION_EVENTS=1 ENABLE_TOUCH_EVENTS=1 ENABLE_DATABASE=1 ENABLE_OFFLINE_WEB_APPLICATIONS=1 ENABLE_DOM_STORAGE=1 ENABLE_VIDEO=1 ENABLE_WORKERS=1 ENABLE_GEOLOCATION=1 ENABLE_CHANNEL_MESSAGING=1 ENABLE_CONNECTION=1 +FEATURE_DEFINES := ENABLE_ORIENTATION_EVENTS=1 ENABLE_TOUCH_EVENTS=1 ENABLE_DATABASE=1 ENABLE_OFFLINE_WEB_APPLICATIONS=1 ENABLE_DOM_STORAGE=1 ENABLE_VIDEO=1 ENABLE_WORKERS=1 ENABLE_GEOLOCATION=1 ENABLE_CHANNEL_MESSAGING=1 ENABLE_CONNECTION=1 ENABLE_APPLICATION_INSTALLED=1 # CSS GEN := \ diff --git a/WebCore/Android.derived.v8bindings.mk b/WebCore/Android.derived.v8bindings.mk index b598f7e..e4e6796 100644 --- a/WebCore/Android.derived.v8bindings.mk +++ b/WebCore/Android.derived.v8bindings.mk @@ -31,7 +31,7 @@ js_binding_scripts := \ $(LOCAL_PATH)/bindings/scripts/generate-bindings.pl # Add ACCELERATED_COMPOSITING=1 and ENABLE_3D_RENDERING=1 for layers support -FEATURE_DEFINES := ENABLE_ORIENTATION_EVENTS=1 ENABLE_TOUCH_EVENTS=1 V8_BINDING ENABLE_DATABASE=1 ENABLE_OFFLINE_WEB_APPLICATIONS=1 ENABLE_DOM_STORAGE=1 ENABLE_WORKERS=1 ENABLE_VIDEO=1 ENABLE_GEOLOCATION=1 ENABLE_CONNECTION=1 +FEATURE_DEFINES := ENABLE_ORIENTATION_EVENTS=1 ENABLE_TOUCH_EVENTS=1 V8_BINDING ENABLE_DATABASE=1 ENABLE_OFFLINE_WEB_APPLICATIONS=1 ENABLE_DOM_STORAGE=1 ENABLE_WORKERS=1 ENABLE_VIDEO=1 ENABLE_GEOLOCATION=1 ENABLE_CONNECTION=1 ENABLE_APPLICATION_INSTALLED=1 # CSS GEN := \ diff --git a/WebCore/Android.jscbindings.mk b/WebCore/Android.jscbindings.mk index 0802db7..a0a47d5 100644 --- a/WebCore/Android.jscbindings.mk +++ b/WebCore/Android.jscbindings.mk @@ -74,6 +74,7 @@ LOCAL_SRC_FILES += \ bindings/js/JSClipboardCustom.cpp \ bindings/js/JSConsoleCustom.cpp \ bindings/js/JSCoordinatesCustom.cpp \ + bindings/js/JSCustomApplicationInstalledCallback.cpp \ bindings/js/JSCustomPositionCallback.cpp \ bindings/js/JSCustomPositionErrorCallback.cpp \ bindings/js/JSCustomSQLStatementCallback.cpp \ diff --git a/WebCore/Android.v8bindings.mk b/WebCore/Android.v8bindings.mk index b7c9400..602185c 100644 --- a/WebCore/Android.v8bindings.mk +++ b/WebCore/Android.v8bindings.mk @@ -102,6 +102,7 @@ LOCAL_SRC_FILES += \ bindings/v8/custom/V8ClipboardCustom.cpp \ bindings/v8/custom/V8ConsoleCustom.cpp \ bindings/v8/custom/V8CoordinatesCustom.cpp \ + bindings/v8/custom/V8CustomApplicationInstalledCallback.cpp \ bindings/v8/custom/V8CustomEventListener.cpp \ bindings/v8/custom/V8CustomPositionCallback.cpp \ bindings/v8/custom/V8CustomPositionErrorCallback.cpp \ diff --git a/WebCore/bindings/js/JSCustomApplicationInstalledCallback.cpp b/WebCore/bindings/js/JSCustomApplicationInstalledCallback.cpp new file mode 100644 index 0000000..37152b8 --- /dev/null +++ b/WebCore/bindings/js/JSCustomApplicationInstalledCallback.cpp @@ -0,0 +1,56 @@ +/* + * Copyright 2010, The Android Open Source Project + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * * Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * * 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 THE COPYRIGHT HOLDERS ``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 THE COPYRIGHT OWNER 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. + */ + +#include "config.h" +#include "JSCustomApplicationInstalledCallback.h" + +#if PLATFORM(ANDROID) && ENABLE(APPLICATION_INSTALLED) + +#include "ScriptController.h" +#include <runtime/JSLock.h> + +namespace WebCore { + +using namespace JSC; + +JSCustomApplicationInstalledCallback::JSCustomApplicationInstalledCallback(JSObject* callback, JSDOMGlobalObject* globalObject) + : m_data(callback, globalObject) +{ +} + +void JSCustomApplicationInstalledCallback::handleEvent(bool isInstalled) +{ + RefPtr<JSCustomApplicationInstalledCallback> protect(this); + + JSC::JSLock lock(SilenceAssertionsOnly); + ExecState* exec = m_data.globalObject()->globalExec(); + MarkedArgumentBuffer args; + args.append(jsBoolean(isInstalled)); + m_data.invokeCallback(args); +} + +} // namespace WebCore + +#endif // PLATFORM(ANDROID) && ENABLE(APPLICATION_INSTALLED) diff --git a/WebCore/bindings/js/JSCustomApplicationInstalledCallback.h b/WebCore/bindings/js/JSCustomApplicationInstalledCallback.h new file mode 100644 index 0000000..d5057a9 --- /dev/null +++ b/WebCore/bindings/js/JSCustomApplicationInstalledCallback.h @@ -0,0 +1,56 @@ +/* + * Copyright 2010, The Android Open Source Project + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * * Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * * 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 THE COPYRIGHT HOLDERS ``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 THE COPYRIGHT OWNER 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. + */ +#if PLATFORM(ANDROID) && ENABLE(APPLICATION_INSTALLED) + +#ifndef JSCustomApplicationInstalledCallback_h +#define JSCustomApplicationInstalledCallback_h + +#include "ApplicationInstalledCallback.h" +#include "JSCallbackData.h" +#include <wtf/PassRefPtr.h> +#include <wtf/RefPtr.h> + +namespace WebCore { + +class JSCustomApplicationInstalledCallback : public ApplicationInstalledCallback { +public: + static PassRefPtr<JSCustomApplicationInstalledCallback> create(JSC::JSObject* callback, JSDOMGlobalObject* globalObject) + { + return adoptRef(new JSCustomApplicationInstalledCallback(callback, globalObject)); + } + + virtual void handleEvent(bool isInstalled); + +private: + JSCustomApplicationInstalledCallback(JSC::JSObject* callback, JSDOMGlobalObject* globalObject); + + JSCallbackData m_data; +}; + +} // namespace WebCore + +#endif // JSCustomApplicationInstalledCallback_h + +#endif // PLATFORM(ANDROID) && ENABLE(APPLICATION_INSTALLED) diff --git a/WebCore/bindings/js/JSNavigatorCustom.cpp b/WebCore/bindings/js/JSNavigatorCustom.cpp index c023931..b30db5a 100644 --- a/WebCore/bindings/js/JSNavigatorCustom.cpp +++ b/WebCore/bindings/js/JSNavigatorCustom.cpp @@ -23,7 +23,13 @@ #include "config.h" #include "JSNavigator.h" +#include "ExceptionCode.h" #include "Navigator.h" +#include <runtime/InternalFunction.h> + +#if PLATFORM(ANDROID) +#include "JSCustomApplicationInstalledCallback.h" +#endif namespace WebCore { @@ -38,4 +44,35 @@ void JSNavigator::markChildren(MarkStack& markStack) markDOMObjectWrapper(markStack, globalData, impl()->optionalGeolocation()); } +#if PLATFORM(ANDROID) && ENABLE(APPLICATION_INSTALLED) + +JSC::JSValue WebCore::JSNavigator::isApplicationInstalled(JSC::ExecState* exec, JSC::ArgList const& args) +{ + if (args.size() < 2) { + setDOMException(exec, SYNTAX_ERR); + return jsUndefined(); + } + + if (!args.at(1).inherits(&InternalFunction::info)) { + setDOMException(exec, TYPE_MISMATCH_ERR); + return jsUndefined(); + } + + String appName = args.at(0).toString(exec); + + JSObject* object; + if (!(object = args.at(1).getObject())) { + setDOMException(exec, TYPE_MISMATCH_ERR); + return jsUndefined(); + } + + RefPtr<ApplicationInstalledCallback> callback(JSCustomApplicationInstalledCallback::create( + object, static_cast<JSDOMGlobalObject*>(exec->dynamicGlobalObject()))); + + m_impl->isApplicationInstalled(appName, callback.release()); + return jsUndefined(); +} + +#endif + } diff --git a/WebCore/bindings/v8/V8Proxy.cpp b/WebCore/bindings/v8/V8Proxy.cpp index 5943e69..7ed1c46 100644 --- a/WebCore/bindings/v8/V8Proxy.cpp +++ b/WebCore/bindings/v8/V8Proxy.cpp @@ -811,11 +811,6 @@ void V8Proxy::createUtilityContext() bool V8Proxy::sourceLineNumber(int& result) { -#if PLATFORM(ANDROID) - // TODO(andreip): consider V8's DEBUG flag here, rather than PLATFORM(ANDROID) - // or, even better, the WEBKIT inspector flag. - return 0; -#else v8::HandleScope scope; v8::Handle<v8::Context> v8UtilityContext = V8Proxy::utilityContext(); if (v8UtilityContext.IsEmpty()) @@ -830,14 +825,10 @@ bool V8Proxy::sourceLineNumber(int& result) return false; result = value->Int32Value(); return true; -#endif } bool V8Proxy::sourceName(String& result) { -#if PLATFORM(ANDROID) - return false; -#else v8::HandleScope scope; v8::Handle<v8::Context> v8UtilityContext = utilityContext(); if (v8UtilityContext.IsEmpty()) @@ -852,7 +843,6 @@ bool V8Proxy::sourceName(String& result) return false; result = toWebCoreString(value); return true; -#endif } void V8Proxy::registerExtensionWithV8(v8::Extension* extension) diff --git a/WebCore/bindings/v8/custom/V8CustomApplicationInstalledCallback.cpp b/WebCore/bindings/v8/custom/V8CustomApplicationInstalledCallback.cpp new file mode 100644 index 0000000..af57b15 --- /dev/null +++ b/WebCore/bindings/v8/custom/V8CustomApplicationInstalledCallback.cpp @@ -0,0 +1,70 @@ +/* + * Copyright 2010, The Android Open Source Project + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * * Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * * 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 THE COPYRIGHT HOLDERS ``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 THE COPYRIGHT OWNER 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. + */ + +#include "config.h" +#include "V8CustomApplicationInstalledCallback.h" + +#if PLATFORM(ANDROID) && ENABLE(APPLICATION_INSTALLED) + +#include "Frame.h" +#include "V8CustomVoidCallback.h" // For invokeCallback + +namespace WebCore { + +V8CustomApplicationInstalledCallback::V8CustomApplicationInstalledCallback(v8::Local<v8::Object> callback, Frame* frame) + : m_callback(v8::Persistent<v8::Object>::New(callback)) + , m_frame(frame) +{ +} + +V8CustomApplicationInstalledCallback::~V8CustomApplicationInstalledCallback() +{ + m_callback.Dispose(); +} + +void V8CustomApplicationInstalledCallback::handleEvent(bool isInstalled) +{ + v8::HandleScope handleScope; + + v8::Handle<v8::Context> context = V8Proxy::context(m_frame.get()); + if (context.IsEmpty()) + return; + + v8::Context::Scope scope(context); + + v8::Handle<v8::Value> argv[] = { + v8::Boolean::New(isInstalled) + }; + + // Protect the frame until the callback returns. + RefPtr<Frame> protector(m_frame); + + bool callbackReturnValue = false; + invokeCallback(m_callback, 1, argv, callbackReturnValue); +} + +} // namespace WebCore + +#endif // PLATFORM(ANDROID) && ENABLE(APPLICATION_INSTALLED) diff --git a/WebCore/bindings/v8/custom/V8CustomApplicationInstalledCallback.h b/WebCore/bindings/v8/custom/V8CustomApplicationInstalledCallback.h new file mode 100644 index 0000000..3bdd2ac --- /dev/null +++ b/WebCore/bindings/v8/custom/V8CustomApplicationInstalledCallback.h @@ -0,0 +1,61 @@ +/* + * Copyright 2010, The Android Open Source Project + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * * Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * * 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 THE COPYRIGHT HOLDERS ``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 THE COPYRIGHT OWNER 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. + */ +#if PLATFORM(ANDROID) && ENABLE(APPLICATION_INSTALLED) + +#ifndef V8CustomApplicationInstalledCallback_h +#define V8CustomApplicationInstalledCallback_h + +#include "ApplicationInstalledCallback.h" +#include <v8.h> +#include <wtf/PassRefPtr.h> +#include <wtf/RefPtr.h> + +namespace WebCore { + +class Frame; + +class V8CustomApplicationInstalledCallback : public ApplicationInstalledCallback { +public: + static PassRefPtr<V8CustomApplicationInstalledCallback> create(v8::Local<v8::Value> value, Frame* frame) + { + ASSERT(value->IsObject()); + return adoptRef(new V8CustomApplicationInstalledCallback(value->ToObject(), frame)); + } + virtual ~V8CustomApplicationInstalledCallback(); + + virtual void handleEvent(bool isInstalled); + +private: + V8CustomApplicationInstalledCallback(v8::Local<v8::Object>, Frame*); + + v8::Persistent<v8::Object> m_callback; + RefPtr<Frame> m_frame; +}; + +} // namespace WebCore + +#endif // V8CustomApplicationInstalledCallback_h + +#endif // PLATFORM(ANDROID) && ENABLE(APPLICATION_INSTALLED) diff --git a/WebCore/bindings/v8/custom/V8NavigatorCustom.cpp b/WebCore/bindings/v8/custom/V8NavigatorCustom.cpp index 266745d..c3c406e 100644 --- a/WebCore/bindings/v8/custom/V8NavigatorCustom.cpp +++ b/WebCore/bindings/v8/custom/V8NavigatorCustom.cpp @@ -32,6 +32,12 @@ #include "V8Navigator.h" #include "RuntimeEnabledFeatures.h" +#include "V8Binding.h" +#include "V8Proxy.h" + +#if PLATFORM(ANDROID) +#include "V8CustomApplicationInstalledCallback.h" +#endif namespace WebCore { @@ -42,4 +48,46 @@ bool V8Navigator::GeolocationEnabled() } #endif +#if PLATFORM(ANDROID) && ENABLE(APPLICATION_INSTALLED) + +static PassRefPtr<ApplicationInstalledCallback> createApplicationInstalledCallback( + v8::Local<v8::Value> value, bool& succeeded) +{ + succeeded = true; + + if (!value->IsFunction()) { + succeeded = false; + throwError("The second argument should be a function"); + return 0; + } + + Frame* frame = V8Proxy::retrieveFrameForCurrentContext(); + return V8CustomApplicationInstalledCallback::create(value, frame); +} + +v8::Handle<v8::Value> V8Navigator::isApplicationInstalledCallback(const v8::Arguments& args) +{ + INC_STATS("DOM.isApplicationInstalled()"); + bool succeeded = false; + + if (args.Length() < 2) + return throwError("Two arguments required: an application name and a callback.", V8Proxy::SyntaxError); + + if (!args[0]->IsString()) + return throwError("The first argument should be a string."); + + RefPtr<ApplicationInstalledCallback> callback = + createApplicationInstalledCallback(args[1], succeeded); + if (!succeeded) + return v8::Undefined(); + + ASSERT(callback); + + Navigator* navigator = V8Navigator::toNative(args.Holder()); + navigator->isApplicationInstalled(toWebCoreString(args[0]), callback.release()); + return v8::Undefined(); +} + +#endif // PLATFORM(ANDROID) && ENABLE(APPLICATION_INSTALLED) + } // namespace WebCore diff --git a/WebCore/config.h b/WebCore/config.h index b8f3a05..4a532b8 100644 --- a/WebCore/config.h +++ b/WebCore/config.h @@ -123,6 +123,8 @@ #undef ENABLE_INSPECTOR // Enabled by default in Platform.h #define ENABLE_INSPECTOR 0 #define ENABLE_EVENT_SOURCE 0 +#undef ENABLE_APPLICATION_INSTALLED +#define ENABLE_APPLICATION_INSTALLED 1 #define FLATTEN_FRAMESET #define FLATTEN_IFRAME diff --git a/WebCore/page/ApplicationInstalledCallback.h b/WebCore/page/ApplicationInstalledCallback.h new file mode 100644 index 0000000..503f9e4 --- /dev/null +++ b/WebCore/page/ApplicationInstalledCallback.h @@ -0,0 +1,45 @@ +/* + * Copyright 2010, The Android Open Source Project + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * * Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * * 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 THE COPYRIGHT HOLDERS ``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 THE COPYRIGHT OWNER 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. + */ +#if PLATFORM(ANDROID) && ENABLE(APPLICATION_INSTALLED) + +#ifndef ApplicationInstalledCallback_h +#define ApplicationInstalledCallback_h + +#include <wtf/Platform.h> +#include <wtf/RefCounted.h> + +namespace WebCore { + +class ApplicationInstalledCallback : public RefCounted<ApplicationInstalledCallback> { +public: + virtual ~ApplicationInstalledCallback() { } + virtual void handleEvent(bool isInstalled) = 0; +}; + +} // namespace WebCore + +#endif // ApplicationInstalledCallback_h + +#endif // PLATFORM(ANDROID) && ENABLE(APPLICATION_INSTALLED) diff --git a/WebCore/page/Navigator.cpp b/WebCore/page/Navigator.cpp index bcc302f..3c0424f 100644 --- a/WebCore/page/Navigator.cpp +++ b/WebCore/page/Navigator.cpp @@ -25,9 +25,6 @@ #include "Chrome.h" #include "CookieJar.h" -#if PLATFORM(ANDROID) -#include "Connection.h" -#endif #include "ExceptionCode.h" #include "Frame.h" #include "FrameLoader.h" @@ -45,6 +42,11 @@ #include "Settings.h" #include "StorageNamespace.h" +#if PLATFORM(ANDROID) +#include "ApplicationInstalledCallback.h" +#include "Connection.h" +#endif + namespace WebCore { Navigator::Navigator(Frame* frame) @@ -168,6 +170,14 @@ Connection* Navigator::connection() const } #endif +#if PLATFORM(ANDROID) && ENABLE(APPLICATION_INSTALLED) +void Navigator::isApplicationInstalled(const String& name, PassRefPtr<ApplicationInstalledCallback> callback) +{ + //TODO(implement); + callback->handleEvent(false); +} +#endif + #if ENABLE(DOM_STORAGE) void Navigator::getStorageUpdates() { diff --git a/WebCore/page/Navigator.h b/WebCore/page/Navigator.h index 9967fba..83ed83f 100644 --- a/WebCore/page/Navigator.h +++ b/WebCore/page/Navigator.h @@ -27,15 +27,17 @@ namespace WebCore { -#if PLATFORM(ANDROID) - class Connection; -#endif class Frame; class Geolocation; class MimeTypeArray; class PluginData; class PluginArray; class String; +#if PLATFORM(ANDROID) + class ApplicationInstalledCallback; + class Connection; +#endif + typedef int ExceptionCode; @@ -64,6 +66,10 @@ namespace WebCore { Connection* connection() const; #endif +#if PLATFORM(ANDROID) && ENABLE(APPLICATION_INSTALLED) + void isApplicationInstalled(const String& name, PassRefPtr<ApplicationInstalledCallback> callback); +#endif + #if ENABLE(DOM_STORAGE) // Relinquishes the storage lock, if one exists. void getStorageUpdates(); diff --git a/WebCore/page/Navigator.idl b/WebCore/page/Navigator.idl index 215316f..8eae9d6 100644 --- a/WebCore/page/Navigator.idl +++ b/WebCore/page/Navigator.idl @@ -45,6 +45,11 @@ module window { readonly attribute Connection connection; #endif +#if defined(ENABLE_APPLICATION_INSTALLED) && ENABLE_APPLICATION_INSTALLED + // ANDROID-only for now. + [Custom] void isApplicationInstalled(in DOMString applicationName, in ApplicationInstalledCallback callback); +#endif + #if defined(ENABLE_GEOLOCATION) && ENABLE_GEOLOCATION readonly attribute [EnabledAtRuntime] Geolocation geolocation; #endif diff --git a/WebCore/platform/android/GeolocationServiceAndroid.cpp b/WebCore/platform/android/GeolocationServiceAndroid.cpp index 3ffb9b9..3d45e75 100644 --- a/WebCore/platform/android/GeolocationServiceAndroid.cpp +++ b/WebCore/platform/android/GeolocationServiceAndroid.cpp @@ -32,6 +32,10 @@ #include "PositionError.h" #include "PositionOptions.h" +#if PLATFORM(ANDROID) +// Required for sim-eng build +#include <math.h> +#endif #include <wtf/CurrentTime.h> using JSC::Bindings::getJNIEnv; diff --git a/WebCore/platform/graphics/android/FontDataAndroid.cpp b/WebCore/platform/graphics/android/FontDataAndroid.cpp index ca54eb3..c915eae 100644 --- a/WebCore/platform/graphics/android/FontDataAndroid.cpp +++ b/WebCore/platform/graphics/android/FontDataAndroid.cpp @@ -81,30 +81,13 @@ SimpleFontData* SimpleFontData::smallCapsFontData(const FontDescription& fontDes return m_smallCapsFontData; } -#define kMaxBufferCount 64 - bool SimpleFontData::containsCharacters(const UChar* characters, int length) const { SkPaint paint; - uint16_t glyphs[kMaxBufferCount]; m_platformData.setupPaint(&paint); paint.setTextEncoding(SkPaint::kUTF16_TextEncoding); - - while (length > 0) { - int n = SkMin32(length, SK_ARRAY_COUNT(glyphs)); - - int count = paint.textToGlyphs(characters, n << 1, glyphs); - for (int i = 0; i < count; i++) { - if (0 == glyphs[i]) { - return false; // missing glyph - } - } - - characters += n; - length -= n; - } - return true; + return paint.containsText(characters, length << 1); } void SimpleFontData::determinePitch() |