diff options
| author | Kristian Monsen <kristianm@google.com> | 2011-07-29 03:37:42 -0700 | 
|---|---|---|
| committer | Android (Google) Code Review <android-gerrit@google.com> | 2011-07-29 03:37:42 -0700 | 
| commit | 910c92cb6b526721c89abf1b7f8c58117a2fd2a2 (patch) | |
| tree | 3b711c5dbc87472da80e97d1175ca15226b9ce6c | |
| parent | c913170859ee56ad32d591e906efea3f8fc95339 (diff) | |
| parent | c3fecb059fd9187bcf77ef9bfa710a012f656d7f (diff) | |
| download | external_webkit-910c92cb6b526721c89abf1b7f8c58117a2fd2a2.zip external_webkit-910c92cb6b526721c89abf1b7f8c58117a2fd2a2.tar.gz external_webkit-910c92cb6b526721c89abf1b7f8c58117a2fd2a2.tar.bz2 | |
Merge changes I48e19e8a,I1ee0fbf6,I1c81bc8c
* changes:
  Part of fix for 5065047: build libchromium as a shared lib
  Preparation for fixing bug 5065047: build libchromium as a shared lib
  Preparation for fixing bug 5065047: build libchromium as a shared lib
| -rw-r--r-- | Android.mk | 3 | ||||
| -rw-r--r-- | Source/WebKit/Android.mk | 1 | ||||
| -rw-r--r-- | Source/WebKit/android/WebCoreSupport/ChromiumIncludes.h | 2 | ||||
| -rw-r--r-- | Source/WebKit/android/WebCoreSupport/ChromiumInit.cpp | 3 | ||||
| -rw-r--r-- | Source/WebKit/android/WebCoreSupport/autofill/FormFieldAndroid.cpp | 139 | ||||
| -rw-r--r-- | Source/WebKit/android/WebCoreSupport/autofill/FormFieldAndroid.h | 75 | ||||
| -rw-r--r-- | Source/WebKit/android/WebCoreSupport/autofill/FormManagerAndroid.cpp | 1 | 
7 files changed, 6 insertions, 218 deletions
| @@ -407,8 +407,7 @@ LOCAL_STATIC_LIBRARIES += libv8  endif  ifeq ($(HTTP_STACK),chrome) -LOCAL_STATIC_LIBRARIES += libchromium_net -LOCAL_SHARED_LIBRARIES += libcrypto libssl libz +LOCAL_SHARED_LIBRARIES += libcrypto libssl libz libchromium_net  endif # HTTP_STACK == chrome  ifeq ($(ENABLE_AUTOFILL),true) diff --git a/Source/WebKit/Android.mk b/Source/WebKit/Android.mk index 3a47909..f3d33c6 100644 --- a/Source/WebKit/Android.mk +++ b/Source/WebKit/Android.mk @@ -131,7 +131,6 @@ LOCAL_CFLAGS += -DENABLE_WEB_AUTOFILL  LOCAL_SRC_FILES += \  	android/WebCoreSupport/autofill/AutoFillHostAndroid.cpp \ -	android/WebCoreSupport/autofill/FormFieldAndroid.cpp \  	android/WebCoreSupport/autofill/FormManagerAndroid.cpp \  	android/WebCoreSupport/autofill/WebAutofill.cpp  endif # ENABLE_AUTOFILL == true diff --git a/Source/WebKit/android/WebCoreSupport/ChromiumIncludes.h b/Source/WebKit/android/WebCoreSupport/ChromiumIncludes.h index 9728aad..022511a 100644 --- a/Source/WebKit/android/WebCoreSupport/ChromiumIncludes.h +++ b/Source/WebKit/android/WebCoreSupport/ChromiumIncludes.h @@ -46,6 +46,7 @@  #endif  #include <android/net/android_network_library_impl.h> +#include <android/jni/jni_utils.h>  #include <base/callback.h>  #include <base/memory/ref_counted.h>  #include <base/message_loop_proxy.h> @@ -95,6 +96,7 @@  #include <chrome/browser/profiles/profile.h>  #include <content/browser/tab_contents/tab_contents.h>  #include <webkit/glue/form_data.h> +#include <webkit/glue/form_field.h>  #endif  #undef LOG diff --git a/Source/WebKit/android/WebCoreSupport/ChromiumInit.cpp b/Source/WebKit/android/WebCoreSupport/ChromiumInit.cpp index 2bb4d3d..500975c 100644 --- a/Source/WebKit/android/WebCoreSupport/ChromiumInit.cpp +++ b/Source/WebKit/android/WebCoreSupport/ChromiumInit.cpp @@ -27,6 +27,8 @@  #include "ChromiumInit.h"  #include "ChromiumIncludes.h" +#include "JNIUtility.h" +#include "jni.h"  #include <cutils/log.h>  #include <string> @@ -68,6 +70,7 @@ void initChromium()          networkChangeNotifier.reset(net::NetworkChangeNotifier::Create());          net::HttpNetworkLayer::EnableSpdy("npn");          initCalled = true; +        jni::SetJavaVM(JSC::Bindings::getJavaVM());      }  } diff --git a/Source/WebKit/android/WebCoreSupport/autofill/FormFieldAndroid.cpp b/Source/WebKit/android/WebCoreSupport/autofill/FormFieldAndroid.cpp deleted file mode 100644 index 3f5970a..0000000 --- a/Source/WebKit/android/WebCoreSupport/autofill/FormFieldAndroid.cpp +++ /dev/null @@ -1,139 +0,0 @@ -/* - * Copyright (c) 2010 The Chromium Authors. All rights reserved. - * 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 "FormFieldAndroid.h" - -#include "ChromiumIncludes.h" -#include "Element.h" -#include "HTMLFormControlElement.h" -#include "HTMLInputElement.h" -#include "HTMLNames.h" -#include "HTMLOptionElement.h" -#include "HTMLSelectElement.h" -#include "StringUtils.h" -#include <wtf/Vector.h> - -using WebCore::Element; -using WebCore::HTMLFormControlElement; -using WebCore::HTMLInputElement; -using WebCore::HTMLOptionElement; -using WebCore::HTMLSelectElement; - -using namespace WebCore::HTMLNames; - -// TODO: This file is taken from chromium/webkit/glue/form_field.cc and -// customised to use WebCore types rather than WebKit API types. It would -// be nice and would ease future merge pain if the two could be combined. - -namespace webkit_glue { - -FormField::FormField() -    : max_length(0), -      is_autofilled(false) { -} - -// TODO: This constructor should probably be deprecated and the -// functionality moved to FormManager. -FormField::FormField(const HTMLFormControlElement& element) -    : max_length(0), -      is_autofilled(false) { -    name = nameForAutofill(element); - -    // TODO: Extract the field label.  For now we just use the field -    // name. -    label = name; - -    form_control_type = formControlType(element); -    if (form_control_type == kText) { -        const HTMLInputElement& input_element = static_cast<const HTMLInputElement&>(element); -        value = WTFStringToString16(input_element.value()); -        max_length = input_element.size(); -        is_autofilled = input_element.isAutofilled(); -    } else if (form_control_type == kSelectOne) { -        const HTMLSelectElement& const_select_element = static_cast<const HTMLSelectElement&>(element); -        HTMLSelectElement& select_element = const_cast<HTMLSelectElement&>(const_select_element); -        value = WTFStringToString16(select_element.value()); - -        // For select-one elements copy option strings. -        WTF::Vector<Element*> list_items = select_element.listItems(); -        option_strings.reserve(list_items.size()); -        for (size_t i = 0; i < list_items.size(); ++i) { -            if (list_items[i]->hasTagName(optionTag)) -                option_strings.push_back(WTFStringToString16(static_cast<HTMLOptionElement*>(list_items[i])->value())); -        } -    } - -    TrimWhitespace(value, TRIM_LEADING, &value); -} - -FormField::FormField(const string16& _label, const string16& _name, const string16& _value, const string16& _form_control_type, int _max_length, bool _is_autofilled) -    : label(_label), -      name(_name), -      value(_value), -      form_control_type(_form_control_type), -      max_length(_max_length), -      is_autofilled(_is_autofilled) { -} - -FormField::~FormField() { -} - -bool FormField::operator==(const FormField& field) const { -    // A FormField stores a value, but the value is not part of the identity of -    // the field, so we don't want to compare the values. -    return (label == field.label && -            name == field.name && -            form_control_type == field.form_control_type && -            max_length == field.max_length); -} - -bool FormField::operator!=(const FormField& field) const { -    return !operator==(field); -} - -bool FormField::StrictlyEqualsHack(const FormField& field) const { -    return (label == field.label && -            name == field.name && -            value == field.value && -            form_control_type == field.form_control_type && -            max_length == field.max_length); -} - -std::ostream& operator<<(std::ostream& os, const FormField& field) { -    return os -            << UTF16ToUTF8(field.label) -            << " " -            << UTF16ToUTF8(field.name) -            << " " -            << UTF16ToUTF8(field.value) -            << " " -            << UTF16ToUTF8(field.form_control_type) -            << " " -            << field.max_length; -} - -}  // namespace webkit_glue diff --git a/Source/WebKit/android/WebCoreSupport/autofill/FormFieldAndroid.h b/Source/WebKit/android/WebCoreSupport/autofill/FormFieldAndroid.h deleted file mode 100644 index 7367f86..0000000 --- a/Source/WebKit/android/WebCoreSupport/autofill/FormFieldAndroid.h +++ /dev/null @@ -1,75 +0,0 @@ -/* - * Copyright (c) 2010 The Chromium Authors. All rights reserved. - * 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. - */ - -#ifndef FormFieldAndroid_h -#define FormFieldAndroid_h - -#include <base/string16.h> -#include <vector> - -// TODO: This file is taken from chromium/webkit/glue/form_field.h and -// customised to use WebCore types rather than WebKit API types. It would -// be nice and would ease future merge pain if the two could be combined. - -namespace WebCore { -class HTMLFormControlElement; -} - -namespace webkit_glue { - -// Stores information about a field in a form. -struct FormField { -    FormField(); -    explicit FormField(const WebCore::HTMLFormControlElement& element); -    FormField(const string16& label, const string16& name, const string16& value, const string16& form_control_type, int max_length, bool is_autofilled); -    virtual ~FormField(); - -    // Equality tests for identity which does not include |value_| or |size_|. -    // Use |StrictlyEqualsHack| method to test all members. -    // TODO: These operators need to be revised when we implement field -    // ids. -    bool operator==(const FormField& field) const; -    bool operator!=(const FormField& field) const; - -    // Test equality of all data members. -    // TODO: This will be removed when we implement field ids. -    bool StrictlyEqualsHack(const FormField& field) const; - -    string16 label; -    string16 name; -    string16 value; -    string16 form_control_type; -    int max_length; -    bool is_autofilled; -    std::vector<string16> option_strings; -}; - -// So we can compare FormFields with EXPECT_EQ(). -std::ostream& operator<<(std::ostream& os, const FormField& field); - -}  // namespace webkit_glue - -#endif  // WEBKIT_GLUE_FORM_FIELD_H_ diff --git a/Source/WebKit/android/WebCoreSupport/autofill/FormManagerAndroid.cpp b/Source/WebKit/android/WebCoreSupport/autofill/FormManagerAndroid.cpp index ba015e2..65b6771 100644 --- a/Source/WebKit/android/WebCoreSupport/autofill/FormManagerAndroid.cpp +++ b/Source/WebKit/android/WebCoreSupport/autofill/FormManagerAndroid.cpp @@ -44,7 +44,6 @@  #include "NodeList.h"  #include "HTMLCollection.h"  #include "FormAssociatedElement.h" -#include "FormFieldAndroid.h"  #include "QualifiedName.h"  #include "StringUtils.h" | 
