diff options
Diffstat (limited to 'Source/WebKit/android')
23 files changed, 165 insertions, 954 deletions
| diff --git a/Source/WebKit/android/AndroidLog.h b/Source/WebKit/android/AndroidLog.h index 3d3eaaa..8f54c02 100644 --- a/Source/WebKit/android/AndroidLog.h +++ b/Source/WebKit/android/AndroidLog.h @@ -27,6 +27,7 @@  #define AndroidLog_h  #ifdef ANDROID_DOM_LOGGING +#include <utils/Log.h>  #include <stdio.h>  extern FILE* gDomTreeFile;  #define DOM_TREE_LOG_FILE "/sdcard/domTree.txt" diff --git a/Source/WebKit/android/TimeCounter.cpp b/Source/WebKit/android/TimeCounter.cpp deleted file mode 100644 index 2393f8a..0000000 --- a/Source/WebKit/android/TimeCounter.cpp +++ /dev/null @@ -1,198 +0,0 @@ -/* - * Copyright 2009, 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. - */ - -#define LOG_TAG "WebCore" - -#include "config.h" -#include "TimeCounter.h" - -#include "MemoryCache.h" -#include "KURL.h" -#include "Node.h" -#include "SystemTime.h" -#include "StyleBase.h" -#include <sys/time.h> -#include <time.h> -#include <utils/Log.h> -#include <wtf/CurrentTime.h> -#include <wtf/text/CString.h> - -#if USE(JSC) -#include "JSDOMWindow.h" -#include <runtime/JSGlobalObject.h> -#include <runtime/JSLock.h> -#endif - -using namespace WebCore; -using namespace WTF; -using namespace JSC; - -namespace android { - -uint32_t getThreadMsec() -{ -#if defined(HAVE_POSIX_CLOCKS) -    struct timespec tm; - -    clock_gettime(CLOCK_THREAD_CPUTIME_ID, &tm); -    return tm.tv_sec * 1000LL + tm.tv_nsec / 1000000; -#else -    struct timeval now; -    struct timezone zone; - -    gettimeofday(&now, &zone); -    return now.tv_sec * 1000LL + now.tv_usec / 1000; -#endif -} - -#ifdef ANDROID_INSTRUMENT - -static double sStartTotalTime; -static uint32_t sStartThreadTime; -static double sLastTotalTime; -static uint32_t sLastThreadTime; - -uint32_t TimeCounter::sStartWebCoreThreadTime; -uint32_t TimeCounter::sEndWebCoreThreadTime; -bool TimeCounter::sRecordWebCoreTime; -uint32_t TimeCounter::sTotalTimeUsed[TimeCounter::TotalTimeCounterCount]; -uint32_t TimeCounter::sLastTimeUsed[TimeCounter::TotalTimeCounterCount]; -uint32_t TimeCounter::sCounter[TimeCounter::TotalTimeCounterCount]; -uint32_t TimeCounter::sLastCounter[TimeCounter::TotalTimeCounterCount]; -uint32_t TimeCounter::sStartTime[TimeCounter::TotalTimeCounterCount]; - -int QemuTracerAuto::reentry_count = 0; - -static const char* timeCounterNames[] = { -    "css parsing",  -    "javascript", -    "javascript init", -    "javascript parsing", -    "javascript execution", -    "calculate style",  -    "Java callback (frame bridge)", -    "parsing (may include calcStyle, Java callback or inline script execution)", -    "layout",  -    "native 1 (frame bridge)", -    "native 2 (resource load)",  -    "native 3 (shared timer)",  -    "build nav (webview core)", -    "record content (webview core)", -    "native 4 (webview core)", -    "draw content (webview ui)", -}; - -void TimeCounter::record(enum Type type, const char* functionName) -{ -    recordNoCounter(type, functionName); -    sCounter[type]++; -} - -void TimeCounter::recordNoCounter(enum Type type, const char* functionName) -{ -    uint32_t time = sEndWebCoreThreadTime = getThreadMsec(); -    uint32_t elapsed = time - sStartTime[type]; -    sTotalTimeUsed[type] += elapsed; -    if (elapsed > 1000) -        LOGW("***** %s() used %d ms\n", functionName, elapsed); -} - -void TimeCounter::report(const KURL& url, int live, int dead, size_t arenaSize) -{ -    String urlString = url; -    int totalTime = static_cast<int>((currentTime() - sStartTotalTime) * 1000); -    int threadTime = getThreadMsec() - sStartThreadTime; -    LOGD("*-* Total load time: %d ms, thread time: %d ms for %s\n", -        totalTime, threadTime, urlString.utf8().data()); -    for (Type type = (Type) 0; type < TotalTimeCounterCount; type  -            = (Type) (type + 1)) { -        char scratch[256]; -        int index = sprintf(scratch, "*-* Total %s time: %d ms",  -            timeCounterNames[type], sTotalTimeUsed[type]); -        if (sCounter[type] > 0) -            sprintf(&scratch[index], " called %d times", sCounter[type]); -        LOGD("%s", scratch); -    } -    LOGD("Current cache has %d bytes live and %d bytes dead", live, dead); -    LOGD("Current render arena takes %d bytes", arenaSize); -#if USE(JSC) -    JSLock lock(false); -    Heap::Statistics jsHeapStatistics = JSDOMWindow::commonJSGlobalData()->heap.statistics(); -    LOGD("Current JavaScript heap size is %d and has %d bytes free", -            jsHeapStatistics.size, jsHeapStatistics.free); -#endif -    LOGD("Current CSS styles use %d bytes", StyleBase::reportStyleSize()); -    LOGD("Current DOM nodes use %d bytes", WebCore::Node::reportDOMNodesSize()); -} - -void TimeCounter::reportNow() -{ -    double current = currentTime(); -    uint32_t currentThread = getThreadMsec(); -    int elapsedTime = static_cast<int>((current - sLastTotalTime) * 1000); -    int elapsedThreadTime = currentThread - sLastThreadTime; -    LOGD("*-* Elapsed time: %d ms, ui thread time: %d ms, webcore thread time:" -        " %d ms\n", elapsedTime, elapsedThreadTime, sEndWebCoreThreadTime - -        sStartWebCoreThreadTime); -    for (Type type = (Type) 0; type < TotalTimeCounterCount; type  -            = (Type) (type + 1)) { -        if (sTotalTimeUsed[type] == sLastTimeUsed[type]) -            continue; -        char scratch[256]; -        int index = sprintf(scratch, "*-* Diff %s time: %d ms", -            timeCounterNames[type], sTotalTimeUsed[type] - sLastTimeUsed[type]); -        if (sCounter[type] > sLastCounter[type]) -            sprintf(&scratch[index], " called %d times", sCounter[type] -                - sLastCounter[type]); -        LOGD("%s", scratch); -    } -    memcpy(sLastTimeUsed, sTotalTimeUsed, sizeof(sTotalTimeUsed)); -    memcpy(sLastCounter, sCounter, sizeof(sCounter)); -    sLastTotalTime = current; -    sLastThreadTime = currentThread; -    sRecordWebCoreTime = true; -} - -void TimeCounter::reset() { -    bzero(sTotalTimeUsed, sizeof(sTotalTimeUsed)); -    bzero(sCounter, sizeof(sCounter)); -    LOGD("*-* Start browser instrument\n"); -    sStartTotalTime = currentTime(); -    sStartThreadTime = getThreadMsec(); -} - -void TimeCounter::start(enum Type type) -{ -    uint32_t time = getThreadMsec(); -    if (sRecordWebCoreTime) { -        sStartWebCoreThreadTime = time; -        sRecordWebCoreTime = false; -    } -    sStartTime[type] = time; -} - -#endif  // ANDROID_INSTRUMENT - -} diff --git a/Source/WebKit/android/TimeCounter.h b/Source/WebKit/android/TimeCounter.h deleted file mode 100644 index ecede27..0000000 --- a/Source/WebKit/android/TimeCounter.h +++ /dev/null @@ -1,120 +0,0 @@ -/* - * Copyright 2009, 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 TimeCounter_h -#define TimeCounter_h - -#include "hardware_legacy/qemu_tracing.h" - -namespace WebCore { - -class KURL; - -} - -namespace android { - -uint32_t getThreadMsec(); - -#ifdef ANDROID_INSTRUMENT - -class TimeCounter { -public: -    enum Type { -        // function base counters -        CSSParseTimeCounter, -        JavaScriptTimeCounter, -        JavaScriptInitTimeCounter, -        JavaScriptParseTimeCounter, -        JavaScriptExecuteTimeCounter, -        CalculateStyleTimeCounter, -        JavaCallbackTimeCounter, -        ParsingTimeCounter, -        LayoutTimeCounter, -        // file base counters -        NativeCallbackTimeCounter,  // WebCoreFrameBridge.cpp -        ResourceTimeCounter,        // WebCoreResourceLoader.cpp -        SharedTimerTimeCounter,     // JavaBridge.cpp -        WebViewCoreBuildNavTimeCounter, -        WebViewCoreRecordTimeCounter, -        WebViewCoreTimeCounter,     // WebViewCore.cpp -        WebViewUIDrawTimeCounter, -        TotalTimeCounterCount -    }; - -    static void record(enum Type type, const char* functionName); -    static void recordNoCounter(enum Type type, const char* functionName); -    static void report(const WebCore::KURL& , int live, int dead, size_t arenaSize); -    static void reportNow(); -    static void reset(); -    static void start(enum Type type); -private: -    static uint32_t sStartWebCoreThreadTime; -    static uint32_t sEndWebCoreThreadTime; -    static bool sRecordWebCoreTime; -    static uint32_t sTotalTimeUsed[TotalTimeCounterCount]; -    static uint32_t sLastTimeUsed[TotalTimeCounterCount]; -    static uint32_t sCounter[TotalTimeCounterCount]; -    static uint32_t sLastCounter[TotalTimeCounterCount]; -    static uint32_t sStartTime[TotalTimeCounterCount]; -    friend class TimeCounterAuto; -}; - -class TimeCounterAuto { -public: -    TimeCounterAuto(TimeCounter::Type type) :  -        m_type(type), m_startTime(getThreadMsec()) {} -    ~TimeCounterAuto() { -        uint32_t time = getThreadMsec(); -        TimeCounter::sEndWebCoreThreadTime = time; -        TimeCounter::sTotalTimeUsed[m_type] += time - m_startTime; -        TimeCounter::sCounter[m_type]++; -    } -private: -    TimeCounter::Type m_type; -    uint32_t m_startTime; -}; - -class QemuTracerAuto { -public: -    QemuTracerAuto() { -        if (!reentry_count) -            qemu_start_tracing(); -        reentry_count++; -    } - -    ~QemuTracerAuto() { -        reentry_count--; -        if (!reentry_count) -            qemu_stop_tracing(); -    } -private: -    static int reentry_count; -}; -#endif  // ANDROID_INSTRUMENT - -} - -#endif diff --git a/Source/WebKit/android/WebCoreSupport/ChromiumIncludes.h b/Source/WebKit/android/WebCoreSupport/ChromiumIncludes.h index 022511a..e59fe09 100644 --- a/Source/WebKit/android/WebCoreSupport/ChromiumIncludes.h +++ b/Source/WebKit/android/WebCoreSupport/ChromiumIncludes.h @@ -45,9 +45,20 @@  #undef LOG_ASSERT  #endif +// Chromium won't build without NDEBUG set, so we set it for all source files +// that use Chromium code. This means that if NDEBUG was previously unset, we +// have to redefine ASSERT() to a no-op, as this is enabled in debug builds. +// Unfortunately, ASSERT() is defined from config.h, so we can't get in first. +#ifndef NDEBUG +#define NDEBUG 1 +#undef ASSERT +#define ASSERT(assertion) (void(0)) +#endif +  #include <android/net/android_network_library_impl.h>  #include <android/jni/jni_utils.h>  #include <base/callback.h> +#include <base/lazy_instance.h>  #include <base/memory/ref_counted.h>  #include <base/message_loop_proxy.h>  #include <base/openssl_util.h> diff --git a/Source/WebKit/android/WebCoreSupport/FrameLoaderClientAndroid.cpp b/Source/WebKit/android/WebCoreSupport/FrameLoaderClientAndroid.cpp index 0be31eb..d26d523 100644 --- a/Source/WebKit/android/WebCoreSupport/FrameLoaderClientAndroid.cpp +++ b/Source/WebKit/android/WebCoreSupport/FrameLoaderClientAndroid.cpp @@ -267,11 +267,11 @@ void FrameLoaderClientAndroid::dispatchDidReceiveIcon() {      // There is a bug in webkit where cancelling an icon load is treated as a      // failure. When this is fixed, we can ASSERT again that we have an icon.      if (icon) { -        LOGV("Received icon (%p) for %s", icon, +        ALOGV("Received icon (%p) for %s", icon,                  url.utf8().data());          m_webFrame->didReceiveIcon(icon);      } else { -        LOGV("Icon data for %s unavailable, registering for notification...", +        ALOGV("Icon data for %s unavailable, registering for notification...",                  url.utf8().data());          registerForIconNotification();      } @@ -1016,7 +1016,7 @@ WTF::PassRefPtr<WebCore::Frame> FrameLoaderClientAndroid::createFrame(const KURL      newFrame->setView(frameView);      newFrame->init();      newFrame->selection()->setFocused(true); -    LOGV("::WebCore:: createSubFrame returning %p", newFrame); +    ALOGV("::WebCore:: createSubFrame returning %p", newFrame);      // The creation of the frame may have run arbitrary JavaScript that removed it from the page already.      if (!pFrame->page()) @@ -1331,8 +1331,8 @@ void FrameLoaderClientAndroid::dispatchDidClearWindowObjectInWorld(DOMWrapperWor          return;      ASSERT(m_frame); -    LOGV("::WebCore:: windowObjectCleared called on frame %p for %s\n", -    		m_frame, m_frame->loader()->url().string().ascii().data()); +    ALOGV("::WebCore:: windowObjectCleared called on frame %p for %s\n", +            m_frame, m_frame->document()->url().string().ascii().data());      m_webFrame->windowObjectCleared(m_frame);  } diff --git a/Source/WebKit/android/WebCoreSupport/V8Counters.cpp b/Source/WebKit/android/WebCoreSupport/V8Counters.cpp deleted file mode 100644 index d164f9a..0000000 --- a/Source/WebKit/android/WebCoreSupport/V8Counters.cpp +++ /dev/null @@ -1,116 +0,0 @@ -/* - * 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. - */ - - -#ifdef ANDROID_INSTRUMENT - -#define LOG_TAG "WebCore" - -#include "config.h" -#include "V8Counters.h" - -#include "NotImplemented.h" -#include <utils/Log.h> -#include <wtf/text/CString.h> -#include <wtf/text/StringHash.h> - -#if USE(V8) - -namespace WebCore { - -V8Counters::Counter::Counter(bool isHistogram) -    : m_count(0), m_sampleTotal(0), m_isHistogram(isHistogram) { } - -void V8Counters::Counter::addSample(int sample) -{ -  m_count++; -  m_sampleTotal += sample; -} - -HashMap<String, V8Counters::Counter*> V8Counters::m_counters; - -// static -int* V8Counters::counterForName(const char* name) -{ -    Counter* counter = m_counters.get(name); -    if (!counter) { -        counter = new Counter(false); -        m_counters.add(name, counter); -    } -    return *counter; -} - -// static -void* V8Counters::createHistogram(const char* name, int min, int max, -        size_t buckets) -{ -    Counter* counter = new Counter(true); -    m_counters.add(name, counter); -    return counter; -} - -// static -void V8Counters::addHistogramSample(void* histogram, int sample) -{ -    Counter* counter = reinterpret_cast<Counter*>(histogram); -    counter->addSample(sample); -} - -// static -void V8Counters::initCounters() -{ -    static bool isInitialized = false; -    if (!isInitialized) { -        v8::V8::SetCounterFunction(counterForName); -        v8::V8::SetCreateHistogramFunction(createHistogram); -        v8::V8::SetAddHistogramSampleFunction(addHistogramSample); -        isInitialized = true; -    } -} - -// static -void V8Counters::dumpCounters() -{ -    LOGD("+----------------------------------------+-------------+\n"); -    LOGD("| Name                                   | Value       |\n"); -    LOGD("+----------------------------------------+-------------+\n"); -    typedef HashMap<String, V8Counters::Counter*>::iterator CounterIterator; -    for (CounterIterator iter = m_counters.begin(); iter != m_counters.end(); ++iter) { -        Counter* counter = iter->second; -        if (counter->isHistogram()) { -            LOGD("| c:%-36s | %11i |\n", iter->first.latin1().data(), counter->count()); -            LOGD("| t:%-36s | %11i |\n", iter->first.latin1().data(), counter->sampleTotal()); -          } else { -            LOGD("| %-38s | %11i |\n", iter->first.latin1().data(), counter->count()); -          } -    } -    LOGD("+----------------------------------------+-------------+\n"); -} - -} - -#endif // ANDROID_INSTRUMENT - -#endif // USE(V8) diff --git a/Source/WebKit/android/WebCoreSupport/V8Counters.h b/Source/WebKit/android/WebCoreSupport/V8Counters.h deleted file mode 100644 index 499b856..0000000 --- a/Source/WebKit/android/WebCoreSupport/V8Counters.h +++ /dev/null @@ -1,77 +0,0 @@ -/* - * 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 V8Counters_h -#define V8Counters_h - -#if USE(V8) - -#ifdef ANDROID_INSTRUMENT - -#include <PlatformString.h> -#include <v8.h> -#include <wtf/HashMap.h> - -namespace WebCore { - -class V8Counters { -public: -    // Counter callbacks, see v8.h -    static int* counterForName(const char* name); - -    static void* createHistogram(const char* name, -                                 int min, -                                 int max, -                                 size_t buckets); - -    static void addHistogramSample(void* histogram, int sample); - -    static void initCounters(); -    static void dumpCounters(); -private: -    class Counter { -    public: -        Counter(bool isHistogram); - -        int count() { return m_count; } -        int sampleTotal() { return m_sampleTotal; } -        bool isHistogram() { return m_isHistogram; } -        void addSample(int32_t sample); - -        operator int*() { return &m_count; } -    private: -        int m_count; -        int m_sampleTotal; -        bool m_isHistogram; -    }; - -    static HashMap<String, Counter*> m_counters; -}; - -} - -#endif // ANDROID_INSTRUMENT -#endif // USE(V8) -#endif // V8Counters_h diff --git a/Source/WebKit/android/WebCoreSupport/WebCookieJar.cpp b/Source/WebKit/android/WebCoreSupport/WebCookieJar.cpp index 1dc4637..0af3cc2 100644 --- a/Source/WebKit/android/WebCoreSupport/WebCookieJar.cpp +++ b/Source/WebKit/android/WebCoreSupport/WebCookieJar.cpp @@ -98,7 +98,7 @@ static std::string databaseDirectory(bool isPrivateBrowsing)      return databaseFilePath;  } -scoped_refptr<WebCookieJar>* instance(bool isPrivateBrowsing) +static scoped_refptr<WebCookieJar>* instance(bool isPrivateBrowsing)  {      static scoped_refptr<WebCookieJar> regularInstance;      static scoped_refptr<WebCookieJar> privateInstance; @@ -127,10 +127,16 @@ void WebCookieJar::cleanup(bool isPrivateBrowsing)  }  WebCookieJar::WebCookieJar(const std::string& databaseFilePath) -    : m_allowCookies(true) -{ +    : m_cookieStoreInitialized(false) +    , m_databaseFilePath(databaseFilePath) +    , m_allowCookies(true) {} + +void WebCookieJar::initCookieStore() { +    MutexLocker lock(m_cookieStoreInitializeMutex); +    if (m_cookieStoreInitialized) +        return;      // Setup the permissions for the file -    const char* cDatabasePath = databaseFilePath.c_str(); +    const char* cDatabasePath = m_databaseFilePath.c_str();      mode_t mode = S_IRUSR | S_IWUSR | S_IRGRP | S_IWGRP;      if (access(cDatabasePath, F_OK) == 0)          chmod(cDatabasePath, mode); @@ -140,9 +146,10 @@ WebCookieJar::WebCookieJar(const std::string& databaseFilePath)              close(fd);      } -    FilePath cookiePath(databaseFilePath.c_str()); +    FilePath cookiePath(cDatabasePath);      m_cookieDb = new SQLitePersistentCookieStore(cookiePath);      m_cookieStore = new net::CookieMonster(m_cookieDb.get(), 0); +    m_cookieStoreInitialized = true;  }  bool WebCookieJar::allowCookies() @@ -157,13 +164,6 @@ void WebCookieJar::setAllowCookies(bool allow)      m_allowCookies = allow;  } -int WebCookieJar::getNumCookiesInDatabase() -{ -    if (!m_cookieStore) -        return 0; -    return m_cookieStore->GetCookieMonster()->GetAllCookies().size(); -} -  // From CookiePolicy in chromium  int WebCookieJar::CanGetCookies(const GURL&, const GURL&) const  { @@ -178,6 +178,17 @@ int WebCookieJar::CanSetCookie(const GURL&, const GURL&, const std::string&) con      return m_allowCookies ? net::OK : net::ERR_ACCESS_DENIED;  } +net::CookieStore* WebCookieJar::cookieStore() +{ +    initCookieStore(); +    return m_cookieStore.get(); +} + +int WebCookieJar::getNumCookiesInDatabase() +{ +    return cookieStore()->GetCookieMonster()->GetAllCookies().size(); +} +  class FlushSemaphore : public base::RefCounted<FlushSemaphore>  {  public: diff --git a/Source/WebKit/android/WebCoreSupport/WebCookieJar.h b/Source/WebKit/android/WebCoreSupport/WebCookieJar.h index b6490af..7ade9d0 100644 --- a/Source/WebKit/android/WebCoreSupport/WebCookieJar.h +++ b/Source/WebKit/android/WebCoreSupport/WebCookieJar.h @@ -55,9 +55,10 @@ public:      static bool acceptFileSchemeCookies();      static void setAcceptFileSchemeCookies(bool); +    // TODO      // Instead of this it would probably be better to add the cookie methods      // here so the rest of WebKit doesn't have to know about Chromium classes -    net::CookieStore* cookieStore() { return m_cookieStore.get(); } +    net::CookieStore* cookieStore();      net::CookiePolicy* cookiePolicy() { return this; }      // Get the number of cookies that have actually been saved to flash. @@ -66,7 +67,13 @@ public:  private:      WebCookieJar(const std::string& databaseFilePath); +    void initCookieStore(); +private: +    bool m_cookieStoreInitialized; +    WTF::Mutex m_cookieStoreInitializeMutex; + +    const std::string m_databaseFilePath;      scoped_refptr<SQLitePersistentCookieStore> m_cookieDb;      scoped_refptr<net::CookieStore> m_cookieStore;      bool m_allowCookies; diff --git a/Source/WebKit/android/WebCoreSupport/WebRequest.cpp b/Source/WebKit/android/WebCoreSupport/WebRequest.cpp index 90b0939..c239b80 100644 --- a/Source/WebKit/android/WebCoreSupport/WebRequest.cpp +++ b/Source/WebKit/android/WebCoreSupport/WebRequest.cpp @@ -30,6 +30,7 @@  #include "MainThread.h"  #include "UrlInterceptResponse.h"  #include "WebCoreFrameBridge.h" +#include "WebCoreJni.h"  #include "WebRequestContext.h"  #include "WebResourceRequest.h"  #include "WebUrlLoaderClient.h" @@ -58,7 +59,24 @@ while (0)  namespace android {  namespace { -    const int kInitialReadBufSize = 32768; +const int kInitialReadBufSize = 32768; +const char* kXRequestedWithHeader = "X-Requested-With"; + +struct RequestPackageName { +    std::string value; +    RequestPackageName(); +}; + +RequestPackageName::RequestPackageName() { +    JNIEnv* env = JSC::Bindings::getJNIEnv(); +    jclass bridgeClass = env->FindClass("android/webkit/JniUtil"); +    jmethodID method = env->GetStaticMethodID(bridgeClass, "getPackageName", "()Ljava/lang/String;"); +    value = jstringToStdString(env, static_cast<jstring>(env->CallStaticObjectMethod(bridgeClass, method))); +    env->DeleteLocalRef(bridgeClass); +} + +base::LazyInstance<RequestPackageName> s_packageName(base::LINKER_INITIALIZED); +  }  WebRequest::WebRequest(WebUrlLoaderClient* loader, const WebResourceRequest& webResourceRequest) @@ -79,6 +97,7 @@ WebRequest::WebRequest(WebUrlLoaderClient* loader, const WebResourceRequest& web      m_request = new net::URLRequest(gurl, this);      m_request->SetExtraRequestHeaders(webResourceRequest.requestHeaders()); +    m_request->SetExtraRequestHeaderByName(kXRequestedWithHeader, s_packageName.Get().value, true);      m_request->set_referrer(webResourceRequest.referrer());      m_request->set_method(webResourceRequest.method());      m_request->set_load_flags(webResourceRequest.loadFlags()); diff --git a/Source/WebKit/android/WebCoreSupport/WebUrlLoaderClient.cpp b/Source/WebKit/android/WebCoreSupport/WebUrlLoaderClient.cpp index a6e58c8..3ca841f 100644 --- a/Source/WebKit/android/WebCoreSupport/WebUrlLoaderClient.cpp +++ b/Source/WebKit/android/WebCoreSupport/WebUrlLoaderClient.cpp @@ -37,6 +37,7 @@  #include "WebRequest.h"  #include "WebResourceRequest.h" +#include <utils/Log.h>  #include <wtf/text/CString.h>  using base::Lock; diff --git a/Source/WebKit/android/WebCoreSupport/WebViewClientError.cpp b/Source/WebKit/android/WebCoreSupport/WebViewClientError.cpp index 260c76e..1857e9c 100644 --- a/Source/WebKit/android/WebCoreSupport/WebViewClientError.cpp +++ b/Source/WebKit/android/WebCoreSupport/WebViewClientError.cpp @@ -79,6 +79,7 @@ WebViewClientError ToWebViewClientError(net::Error error) {          case ERR_CONNECTION_ABORTED:          case ERR_CONNECTION_FAILED:          case ERR_SOCKET_NOT_CONNECTED: +        case ERR_CACHE_MISS:              return ERROR_CONNECT;          case ERR_ADDRESS_INVALID: diff --git a/Source/WebKit/android/WebCoreSupport/autofill/FormManagerAndroid.cpp b/Source/WebKit/android/WebCoreSupport/autofill/FormManagerAndroid.cpp index e837244..2969252 100644 --- a/Source/WebKit/android/WebCoreSupport/autofill/FormManagerAndroid.cpp +++ b/Source/WebKit/android/WebCoreSupport/autofill/FormManagerAndroid.cpp @@ -562,7 +562,7 @@ void FormManager::ExtractForms(Frame* frame) {      ResetFrame(frame); -    WTF::PassRefPtr<HTMLCollection> web_forms = frame->document()->forms(); +    WTF::RefPtr<HTMLCollection> web_forms = frame->document()->forms();      for (size_t i = 0; i < web_forms->length(); ++i) {          // Owned by |form_elements|. diff --git a/Source/WebKit/android/jni/JavaBridge.cpp b/Source/WebKit/android/jni/JavaBridge.cpp index 68eb367..60f4523 100644 --- a/Source/WebKit/android/jni/JavaBridge.cpp +++ b/Source/WebKit/android/jni/JavaBridge.cpp @@ -41,9 +41,6 @@  #include "PluginDatabase.h"  #include "Timer.h"  #include "TimerClient.h" -#ifdef ANDROID_INSTRUMENT -#include "TimeCounter.h" -#endif  #include "WebCache.h"  #include "WebCoreJni.h" @@ -364,7 +361,7 @@ void JavaBridge::Finalize(JNIEnv* env, jobject obj)      JavaBridge* javaBridge = (JavaBridge*)          (env->GetIntField(obj, gJavaBridge_ObjectID));          LOG_ASSERT(javaBridge, "Finalize should not be called twice for the same java bridge!"); -    LOGV("webcore_javabridge::nativeFinalize(%p)\n", javaBridge); +    ALOGV("webcore_javabridge::nativeFinalize(%p)\n", javaBridge);      delete javaBridge;      env->SetIntField(obj, gJavaBridge_ObjectID, 0);  } @@ -374,14 +371,8 @@ void JavaBridge::SharedTimerFired(JNIEnv* env, jobject)  {      if (sSharedTimerFiredCallback)      { -#ifdef ANDROID_INSTRUMENT -        TimeCounter::start(TimeCounter::SharedTimerTimeCounter); -#endif          SkAutoMemoryUsageProbe  mup("JavaBridge::sharedTimerFired");          sSharedTimerFiredCallback(); -#ifdef ANDROID_INSTRUMENT -        TimeCounter::record(TimeCounter::SharedTimerTimeCounter, __FUNCTION__); -#endif      }  } diff --git a/Source/WebKit/android/jni/PictureSet.cpp b/Source/WebKit/android/jni/PictureSet.cpp index 4d9d16c..1bd72bd 100644 --- a/Source/WebKit/android/jni/PictureSet.cpp +++ b/Source/WebKit/android/jni/PictureSet.cpp @@ -36,7 +36,6 @@  #include "SkRect.h"  #include "SkRegion.h"  #include "SkStream.h" -#include "TimeCounter.h"  #define MAX_DRAW_TIME 100  #define MIN_SPLITTABLE 400 @@ -693,6 +692,22 @@ void PictureSet::clear()      mWidth = mHeight = 0;  } +uint32_t getThreadMsec() +{ +#if defined(HAVE_POSIX_CLOCKS) +    struct timespec tm; + +    clock_gettime(CLOCK_THREAD_CPUTIME_ID, &tm); +    return tm.tv_sec * 1000LL + tm.tv_nsec / 1000000; +#else +    struct timeval now; +    struct timezone zone; + +    gettimeofday(&now, &zone); +    return now.tv_sec * 1000LL + now.tv_usec / 1000; +#endif +} +  bool PictureSet::draw(SkCanvas* canvas)  {  #ifdef FAST_PICTURESET diff --git a/Source/WebKit/android/jni/WebCoreFrameBridge.cpp b/Source/WebKit/android/jni/WebCoreFrameBridge.cpp index d53ddb6..79494e6 100644 --- a/Source/WebKit/android/jni/WebCoreFrameBridge.cpp +++ b/Source/WebKit/android/jni/WebCoreFrameBridge.cpp @@ -116,13 +116,8 @@  #elif USE(V8)  #include "JavaNPObjectV8.h"  #include "JavaInstanceJobjectV8.h" -#include "V8Counters.h"  #endif  // USE(JSC) -#ifdef ANDROID_INSTRUMENT -#include "TimeCounter.h" -#endif -  #if ENABLE(WEB_AUTOFILL)  #include "autofill/WebAutofill.h"  #endif @@ -422,10 +417,7 @@ WebFrame::startLoadingResource(WebCore::ResourceHandle* loader,                                    bool mainResource,                                    bool synchronous)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::JavaCallbackTimeCounter); -#endif -    LOGV("::WebCore:: startLoadingResource(%p, %s)", +    ALOGV("::WebCore:: startLoadingResource(%p, %s)",              loader, request.url().string().latin1().data());      JNIEnv* env = getJNIEnv(); @@ -449,7 +441,7 @@ WebFrame::startLoadingResource(WebCore::ResourceHandle* loader,                      + urlStr.substring(colon);          }      } -    LOGV("%s lower=%s", __FUNCTION__, urlStr.latin1().data()); +    ALOGV("%s lower=%s", __FUNCTION__, urlStr.latin1().data());      jstring jUrlStr = wtfStringToJstring(env, urlStr);      jstring jMethodStr = NULL;      if (!method.isEmpty()) @@ -475,7 +467,7 @@ WebFrame::startLoadingResource(WebCore::ResourceHandle* loader,              break;      } -    LOGV("::WebCore:: startLoadingResource %s with cacheMode %d", urlStr.ascii().data(), cacheMode); +    ALOGV("::WebCore:: startLoadingResource %s with cacheMode %d", urlStr.ascii().data(), cacheMode);      ResourceHandleInternal* loaderInternal = loader->getInternal();      jstring jUsernameString = loaderInternal->m_user.isEmpty() ? @@ -500,7 +492,7 @@ WebFrame::startLoadingResource(WebCore::ResourceHandle* loader,      if (checkException(env))          return 0; -    PassRefPtr<WebCore::ResourceLoaderAndroid> h; +    RefPtr<WebCore::ResourceLoaderAndroid> h;      if (jLoadListener)          h = WebCoreResourceLoader::create(env, jLoadListener);      env->DeleteLocalRef(jLoadListener); @@ -510,10 +502,7 @@ WebFrame::startLoadingResource(WebCore::ResourceHandle* loader,  UrlInterceptResponse*  WebFrame::shouldInterceptRequest(const WTF::String& url)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::JavaCallbackTimeCounter); -#endif -    LOGV("::WebCore:: shouldInterceptRequest(%s)", url.latin1().data()); +    ALOGV("::WebCore:: shouldInterceptRequest(%s)", url.latin1().data());      JNIEnv* env = getJNIEnv();      AutoJObject javaFrame = mJavaFrame->frame(env); @@ -534,10 +523,7 @@ void  WebFrame::reportError(int errorCode, const WTF::String& description,          const WTF::String& failingUrl)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::JavaCallbackTimeCounter); -#endif -    LOGV("::WebCore:: reportError(%d, %s)", errorCode, description.ascii().data()); +    ALOGV("::WebCore:: reportError(%d, %s)", errorCode, description.ascii().data());      JNIEnv* env = getJNIEnv();      AutoJObject javaFrame = mJavaFrame->frame(env);      if (!javaFrame.get()) @@ -573,9 +559,6 @@ WebFrame::convertIDNToUnicode(const WebCore::KURL& url) {  void  WebFrame::loadStarted(WebCore::Frame* frame)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::JavaCallbackTimeCounter); -#endif      JNIEnv* env = getJNIEnv();      AutoJObject javaFrame = mJavaFrame->frame(env);      if (!javaFrame.get()) @@ -589,7 +572,7 @@ WebFrame::loadStarted(WebCore::Frame* frame)      const WebCore::KURL& url = documentLoader->url();      if (url.isEmpty())          return; -    LOGV("::WebCore:: loadStarted %s", url.string().ascii().data()); +    ALOGV("::WebCore:: loadStarted %s", url.string().ascii().data());      bool isMainFrame = (!frame->tree() || !frame->tree()->parent());      WebCore::FrameLoadType loadType = frame->loader()->loadType(); @@ -609,7 +592,7 @@ WebFrame::loadStarted(WebCore::Frame* frame)          WebCore::Image* icon = WebCore::iconDatabase().synchronousIconForPageURL(urlString, WebCore::IntSize(16, 16));          if (icon)              favicon = webcoreImageToJavaBitmap(env, icon); -        LOGV("favicons", "Starting load with icon %p for %s", icon, url.string().utf8().data()); +        ALOGV("favicons", "Starting load with icon %p for %s", icon, url.string().utf8().data());      }      jstring urlStr = wtfStringToJstring(env, urlString); @@ -633,9 +616,6 @@ WebFrame::loadStarted(WebCore::Frame* frame)  void  WebFrame::transitionToCommitted(WebCore::Frame* frame)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::JavaCallbackTimeCounter); -#endif      JNIEnv* env = getJNIEnv();      AutoJObject javaFrame = mJavaFrame->frame(env);      if (!javaFrame.get()) @@ -650,9 +630,6 @@ WebFrame::transitionToCommitted(WebCore::Frame* frame)  void  WebFrame::didFinishLoad(WebCore::Frame* frame)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::JavaCallbackTimeCounter); -#endif      JNIEnv* env = getJNIEnv();      AutoJObject javaFrame = mJavaFrame->frame(env);      if (!javaFrame.get()) @@ -667,7 +644,7 @@ WebFrame::didFinishLoad(WebCore::Frame* frame)      const WebCore::KURL& url = documentLoader->url();      if (url.isEmpty())          return; -    LOGV("::WebCore:: didFinishLoad %s", url.string().ascii().data()); +    ALOGV("::WebCore:: didFinishLoad %s", url.string().ascii().data());      bool isMainFrame = (!frame->tree() || !frame->tree()->parent());      WebCore::FrameLoadType loadType = loader->loadType(); @@ -681,10 +658,7 @@ WebFrame::didFinishLoad(WebCore::Frame* frame)  void  WebFrame::addHistoryItem(WebCore::HistoryItem* item)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::JavaCallbackTimeCounter); -#endif -    LOGV("::WebCore:: addHistoryItem"); +    ALOGV("::WebCore:: addHistoryItem");      JNIEnv* env = getJNIEnv();      WebHistory::AddItem(mJavaFrame->history(env), item);  } @@ -692,10 +666,7 @@ WebFrame::addHistoryItem(WebCore::HistoryItem* item)  void  WebFrame::removeHistoryItem(int index)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::JavaCallbackTimeCounter); -#endif -    LOGV("::WebCore:: removeHistoryItem at %d", index); +    ALOGV("::WebCore:: removeHistoryItem at %d", index);      JNIEnv* env = getJNIEnv();      WebHistory::RemoveItem(mJavaFrame->history(env), index);  } @@ -703,10 +674,7 @@ WebFrame::removeHistoryItem(int index)  void  WebFrame::updateHistoryIndex(int newIndex)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::JavaCallbackTimeCounter); -#endif -    LOGV("::WebCore:: updateHistoryIndex to %d", newIndex); +    ALOGV("::WebCore:: updateHistoryIndex to %d", newIndex);      JNIEnv* env = getJNIEnv();      WebHistory::UpdateHistoryIndex(mJavaFrame->history(env), newIndex);  } @@ -714,11 +682,8 @@ WebFrame::updateHistoryIndex(int newIndex)  void  WebFrame::setTitle(const WTF::String& title)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::JavaCallbackTimeCounter); -#endif  #ifndef NDEBUG -    LOGV("setTitle(%s)", title.ascii().data()); +    ALOGV("setTitle(%s)", title.ascii().data());  #endif      JNIEnv* env = getJNIEnv();      AutoJObject javaFrame = mJavaFrame->frame(env); @@ -735,10 +700,7 @@ WebFrame::setTitle(const WTF::String& title)  void  WebFrame::windowObjectCleared(WebCore::Frame* frame)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::JavaCallbackTimeCounter); -#endif -    LOGV("::WebCore:: windowObjectCleared"); +    ALOGV("::WebCore:: windowObjectCleared");      JNIEnv* env = getJNIEnv();      AutoJObject javaFrame = mJavaFrame->frame(env);      if (!javaFrame.get()) @@ -751,9 +713,6 @@ WebFrame::windowObjectCleared(WebCore::Frame* frame)  void  WebFrame::setProgress(float newProgress)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::JavaCallbackTimeCounter); -#endif      JNIEnv* env = getJNIEnv();      AutoJObject javaFrame = mJavaFrame->frame(env);      if (!javaFrame.get()) @@ -773,9 +732,6 @@ WebFrame::userAgentForURL(const WebCore::KURL* url)  void  WebFrame::didReceiveIcon(WebCore::Image* icon)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::JavaCallbackTimeCounter); -#endif      LOG_ASSERT(icon, "DidReceiveIcon called without an image!");      JNIEnv* env = getJNIEnv();      AutoJObject javaFrame = mJavaFrame->frame(env); @@ -794,9 +750,6 @@ WebFrame::didReceiveIcon(WebCore::Image* icon)  void  WebFrame::didReceiveTouchIconURL(const WTF::String& url, bool precomposed)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::JavaCallbackTimeCounter); -#endif      JNIEnv* env = getJNIEnv();      AutoJObject javaFrame = mJavaFrame->frame(env);      if (!javaFrame.get()) @@ -812,9 +765,6 @@ WebFrame::didReceiveTouchIconURL(const WTF::String& url, bool precomposed)  void  WebFrame::updateVisitedHistory(const WebCore::KURL& url, bool reload)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::JavaCallbackTimeCounter); -#endif      JNIEnv* env = getJNIEnv();      AutoJObject javaFrame = mJavaFrame->frame(env);      if (!javaFrame.get()) @@ -831,9 +781,6 @@ WebFrame::updateVisitedHistory(const WebCore::KURL& url, bool reload)  bool  WebFrame::canHandleRequest(const WebCore::ResourceRequest& request)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::JavaCallbackTimeCounter); -#endif      JNIEnv* env = getJNIEnv();      AutoJObject javaFrame = mJavaFrame->frame(env);      if (!javaFrame.get()) @@ -874,9 +821,6 @@ WebFrame::shouldSaveFormData()  WebCore::Frame*  WebFrame::createWindow(bool dialog, bool userGesture)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::JavaCallbackTimeCounter); -#endif      JNIEnv* env = getJNIEnv();      AutoJObject javaFrame = mJavaFrame->frame(env);      if (!javaFrame.get()) @@ -890,9 +834,6 @@ WebFrame::createWindow(bool dialog, bool userGesture)  void  WebFrame::requestFocus() const  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::JavaCallbackTimeCounter); -#endif      JNIEnv* env = getJNIEnv();      AutoJObject javaFrame = mJavaFrame->frame(env);      if (!javaFrame.get()) @@ -904,9 +845,6 @@ WebFrame::requestFocus() const  void  WebFrame::closeWindow(WebViewCore* webViewCore)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::JavaCallbackTimeCounter); -#endif      assert(webViewCore);      JNIEnv* env = getJNIEnv();      AutoJObject javaFrame = mJavaFrame->frame(env); @@ -925,9 +863,6 @@ struct PolicyFunctionWrapper {  void  WebFrame::decidePolicyForFormResubmission(WebCore::FramePolicyFunction func)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::JavaCallbackTimeCounter); -#endif      JNIEnv* env = getJNIEnv();      AutoJObject javaFrame = mJavaFrame->frame(env);      if (!javaFrame.get()) @@ -965,9 +900,6 @@ WebFrame::density() const  void  WebFrame::didReceiveAuthenticationChallenge(WebUrlLoaderClient* client, const std::string& host, const std::string& realm, bool useCachedCredentials, bool suppressDialog)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::JavaCallbackTimeCounter); -#endif      JNIEnv* env = getJNIEnv();      AutoJObject javaFrame = mJavaFrame->frame(env);      if (!javaFrame.get()) @@ -985,9 +917,6 @@ WebFrame::didReceiveAuthenticationChallenge(WebUrlLoaderClient* client, const st  void  WebFrame::reportSslCertError(WebUrlLoaderClient* client, int error, const std::string& cert, const std::string& url)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::JavaCallbackTimeCounter); -#endif      JNIEnv* env = getJNIEnv();      AutoJObject javaFrame = mJavaFrame->frame(env);      if (!javaFrame.get()) @@ -1008,9 +937,6 @@ WebFrame::reportSslCertError(WebUrlLoaderClient* client, int error, const std::s  void  WebFrame::requestClientCert(WebUrlLoaderClient* client, const std::string& hostAndPort)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::JavaCallbackTimeCounter); -#endif      JNIEnv* env = getJNIEnv();      int jHandle = reinterpret_cast<int>(client); @@ -1024,9 +950,6 @@ WebFrame::requestClientCert(WebUrlLoaderClient* client, const std::string& hostA  void  WebFrame::downloadStart(const std::string& url, const std::string& userAgent, const std::string& contentDisposition, const std::string& mimetype, long long contentLength)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::JavaCallbackTimeCounter); -#endif      JNIEnv* env = getJNIEnv();      AutoJObject javaFrame = mJavaFrame->frame(env);      if (!javaFrame.get()) @@ -1047,9 +970,6 @@ WebFrame::downloadStart(const std::string& url, const std::string& userAgent, co  void  WebFrame::didReceiveData(const char* data, int size) { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::JavaCallbackTimeCounter); -#endif      JNIEnv* env = getJNIEnv();      AutoJObject javaFrame = mJavaFrame->frame(env);      if (!javaFrame.get()) @@ -1064,9 +984,6 @@ WebFrame::didReceiveData(const char* data, int size) {  void  WebFrame::didFinishLoading() { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::JavaCallbackTimeCounter); -#endif      JNIEnv* env = getJNIEnv();      AutoJObject javaFrame = mJavaFrame->frame(env);      if (!javaFrame.get()) @@ -1078,9 +995,6 @@ WebFrame::didFinishLoading() {  void WebFrame::setCertificate(const std::string& cert)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::JavaCallbackTimeCounter); -#endif      JNIEnv* env = getJNIEnv();      AutoJObject javaFrame = mJavaFrame->frame(env);      if (!javaFrame.get()) @@ -1098,9 +1012,6 @@ void WebFrame::setCertificate(const std::string& cert)  void WebFrame::autoLogin(const std::string& loginHeader)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimerCoutner::JavaCallbackTimeCounter); -#endif      JNIEnv* env = getJNIEnv();      AutoJObject javaFrame = mJavaFrame->frame(env);      if (!javaFrame.get()) @@ -1174,7 +1085,7 @@ void WebFrame::maybeSavePassword(WebCore::Frame* frame, const WebCore::ResourceR  bool WebFrame::getUsernamePasswordFromDom(WebCore::Frame* frame, WTF::String& username, WTF::String& password)  {      bool found = false; -    WTF::PassRefPtr<WebCore::HTMLCollection> form = frame->document()->forms(); +    WTF::RefPtr<WebCore::HTMLCollection> form = frame->document()->forms();      WebCore::Node* node = form->firstItem();      while (node && !found && !node->namespaceURI().isNull() &&             !node->namespaceURI().isEmpty()) { @@ -1271,9 +1182,6 @@ jbyteArray WebFrame::getPostData(const WebCore::ResourceRequest& request)  static void CallPolicyFunction(JNIEnv* env, jobject obj, jint func, jint decision)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::NativeCallbackTimeCounter); -#endif      WebCore::Frame* pFrame = GET_NATIVE_FRAME(env, obj);      LOG_ASSERT(pFrame, "nativeCallPolicyFunction must take a valid frame pointer!");      PolicyFunctionWrapper* pFunc = (PolicyFunctionWrapper*)func; @@ -1295,12 +1203,6 @@ static void CreateFrame(JNIEnv* env, jobject obj, jobject javaview, jobject jAss      initChromium();  #endif -#ifdef ANDROID_INSTRUMENT -#if USE(V8) -    V8Counters::initCounters(); -#endif -    TimeCounterAuto counter(TimeCounter::NativeCallbackTimeCounter); -#endif      // Create a new page      ChromeClientAndroid* chromeC = new ChromeClientAndroid;      EditorClientAndroid* editorC = new EditorClientAndroid; @@ -1362,7 +1264,7 @@ static void CreateFrame(JNIEnv* env, jobject obj, jobject javaview, jobject jAss      WebCore::SecurityOrigin::setLocalLoadPolicy(              WebCore::SecurityOrigin::AllowLocalLoadsForLocalAndSubstituteData); -    LOGV("::WebCore:: createFrame %p", frame); +    ALOGV("::WebCore:: createFrame %p", frame);      // Set the mNativeFrame field in Frame      SET_NATIVE_FRAME(env, obj, (int)frame); @@ -1384,13 +1286,10 @@ static void CreateFrame(JNIEnv* env, jobject obj, jobject javaview, jobject jAss  static void DestroyFrame(JNIEnv* env, jobject obj)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::NativeCallbackTimeCounter); -#endif      WebCore::Frame* pFrame = GET_NATIVE_FRAME(env, obj);      LOG_ASSERT(pFrame, "nativeDestroyFrame must take a valid frame pointer!"); -    LOGV("::WebCore:: deleting frame %p", pFrame); +    ALOGV("::WebCore:: deleting frame %p", pFrame);      WebCore::FrameView* view = pFrame->view();      view->ref(); @@ -1415,9 +1314,6 @@ static void DestroyFrame(JNIEnv* env, jobject obj)  static void LoadUrl(JNIEnv *env, jobject obj, jstring url, jobject headers)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::NativeCallbackTimeCounter); -#endif      WebCore::Frame* pFrame = GET_NATIVE_FRAME(env, obj);      LOG_ASSERT(pFrame, "nativeLoadUrl must take a valid frame pointer!"); @@ -1463,15 +1359,12 @@ static void LoadUrl(JNIEnv *env, jobject obj, jstring url, jobject headers)          env->DeleteLocalRef(set);          env->DeleteLocalRef(mapClass);      } -    LOGV("LoadUrl %s", kurl.string().latin1().data()); +    ALOGV("LoadUrl %s", kurl.string().latin1().data());      pFrame->loader()->load(request, false);  }  static void PostUrl(JNIEnv *env, jobject obj, jstring url, jbyteArray postData)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::NativeCallbackTimeCounter); -#endif      WebCore::Frame* pFrame = GET_NATIVE_FRAME(env, obj);      LOG_ASSERT(pFrame, "nativePostUrl must take a valid frame pointer!"); @@ -1491,7 +1384,7 @@ static void PostUrl(JNIEnv *env, jobject obj, jstring url, jbyteArray postData)          env->ReleaseByteArrayElements(postData, bytes, 0);      } -    LOGV("PostUrl %s", kurl.string().latin1().data()); +    ALOGV("PostUrl %s", kurl.string().latin1().data());      WebCore::FrameLoadRequest frameRequest(pFrame->document()->securityOrigin(), request);      pFrame->loader()->loadFrameRequest(frameRequest, false, false, 0, 0, WebCore::SendReferrer);  } @@ -1499,9 +1392,6 @@ static void PostUrl(JNIEnv *env, jobject obj, jstring url, jbyteArray postData)  static void LoadData(JNIEnv *env, jobject obj, jstring baseUrl, jstring data,          jstring mimeType, jstring encoding, jstring failUrl)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::NativeCallbackTimeCounter); -#endif      WebCore::Frame* pFrame = GET_NATIVE_FRAME(env, obj);      LOG_ASSERT(pFrame, "nativeLoadData must take a valid frame pointer!"); @@ -1510,7 +1400,7 @@ static void LoadData(JNIEnv *env, jobject obj, jstring baseUrl, jstring data,      // Setup the substituteData      const char* dataStr = env->GetStringUTFChars(data, NULL); -    WTF::PassRefPtr<WebCore::SharedBuffer> sharedBuffer = +    WTF::RefPtr<WebCore::SharedBuffer> sharedBuffer =          WebCore::SharedBuffer::create();      LOG_ASSERT(dataStr, "nativeLoadData has a null data string.");      sharedBuffer->append(dataStr, strlen(dataStr)); @@ -1526,12 +1416,9 @@ static void LoadData(JNIEnv *env, jobject obj, jstring baseUrl, jstring data,  static void StopLoading(JNIEnv *env, jobject obj)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::NativeCallbackTimeCounter); -#endif      WebCore::Frame* pFrame = GET_NATIVE_FRAME(env, obj);      LOG_ASSERT(pFrame, "nativeStopLoading must take a valid frame pointer!"); -    LOGV("::WebCore:: stopLoading %p", pFrame); +    ALOGV("::WebCore:: stopLoading %p", pFrame);      // Stop loading the page and do not send an unload event      pFrame->loader()->stopForUserCancel(); @@ -1626,9 +1513,6 @@ static jstring SaveWebArchive(JNIEnv *env, jobject obj, jstring basename, jboole  static jstring ExternalRepresentation(JNIEnv *env, jobject obj)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::NativeCallbackTimeCounter); -#endif      WebCore::Frame* pFrame = GET_NATIVE_FRAME(env, obj);      LOG_ASSERT(pFrame, "android_webcore_nativeExternalRepresentation must take a valid frame pointer!"); @@ -1661,9 +1545,6 @@ static StringBuilder FrameAsText(WebCore::Frame *pFrame, jboolean dumpChildFrame  static jstring DocumentAsText(JNIEnv *env, jobject obj)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::NativeCallbackTimeCounter); -#endif      WebCore::Frame* pFrame = GET_NATIVE_FRAME(env, obj);      LOG_ASSERT(pFrame, "android_webcore_nativeDocumentAsText must take a valid frame pointer!"); @@ -1673,9 +1554,6 @@ static jstring DocumentAsText(JNIEnv *env, jobject obj)  static jstring ChildFramesAsText(JNIEnv *env, jobject obj)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::NativeCallbackTimeCounter); -#endif      WebCore::Frame* pFrame = GET_NATIVE_FRAME(env, obj);      LOG_ASSERT(pFrame, "android_webcore_nativeDocumentAsText must take a valid frame pointer!"); @@ -1689,9 +1567,6 @@ static jstring ChildFramesAsText(JNIEnv *env, jobject obj)  static void Reload(JNIEnv *env, jobject obj, jboolean allowStale)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::NativeCallbackTimeCounter); -#endif      WebCore::Frame* pFrame = GET_NATIVE_FRAME(env, obj);      LOG_ASSERT(pFrame, "nativeReload must take a valid frame pointer!"); @@ -1709,9 +1584,6 @@ static void Reload(JNIEnv *env, jobject obj, jboolean allowStale)  static void GoBackOrForward(JNIEnv *env, jobject obj, jint pos)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::NativeCallbackTimeCounter); -#endif      WebCore::Frame* pFrame = GET_NATIVE_FRAME(env, obj);      LOG_ASSERT(pFrame, "nativeGoBackOrForward must take a valid frame pointer!"); @@ -1725,9 +1597,6 @@ static void GoBackOrForward(JNIEnv *env, jobject obj, jint pos)  static jobject StringByEvaluatingJavaScriptFromString(JNIEnv *env, jobject obj, jstring script)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::NativeCallbackTimeCounter); -#endif      WebCore::Frame* pFrame = GET_NATIVE_FRAME(env, obj);      LOG_ASSERT(pFrame, "stringByEvaluatingJavaScriptFromString must take a valid frame pointer!"); @@ -1831,9 +1700,6 @@ private:  static void AddJavascriptInterface(JNIEnv *env, jobject obj, jint nativeFramePointer,          jobject javascriptObj, jstring interfaceName)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::NativeCallbackTimeCounter); -#endif      WebCore::Frame* pFrame = 0;      if (nativeFramePointer == 0)          pFrame = GET_NATIVE_FRAME(env, obj); @@ -1843,7 +1709,7 @@ static void AddJavascriptInterface(JNIEnv *env, jobject obj, jint nativeFramePoi      JavaVM* vm;      env->GetJavaVM(&vm); -    LOGV("::WebCore:: addJSInterface: %p", pFrame); +    ALOGV("::WebCore:: addJSInterface: %p", pFrame);  #if USE(JSC)      // Copied from qwebframe.cpp @@ -1893,17 +1759,11 @@ static void AddJavascriptInterface(JNIEnv *env, jobject obj, jint nativeFramePoi  static void SetCacheDisabled(JNIEnv *env, jobject obj, jboolean disabled)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::NativeCallbackTimeCounter); -#endif      WebCore::memoryCache()->setDisabled(disabled);  }  static jboolean CacheDisabled(JNIEnv *env, jobject obj)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::NativeCallbackTimeCounter); -#endif      return WebCore::memoryCache()->disabled();  } @@ -1936,17 +1796,6 @@ static void ClearWebViewCache()  static void ClearCache(JNIEnv *env, jobject obj)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::NativeCallbackTimeCounter); -#if USE(JSC) -    JSC::JSLock lock(false); -    JSC::Heap::Statistics jsHeapStatistics = WebCore::JSDOMWindow::commonJSGlobalData()->heap.statistics(); -    LOGD("About to gc and JavaScript heap size is %d and has %d bytes free", -            jsHeapStatistics.size, jsHeapStatistics.free); -#endif  // USE(JSC) -    LOGD("About to clear cache and current cache has %d bytes live and %d bytes dead", -            memoryCache()->getLiveSize(), memoryCache()->getDeadSize()); -#endif  // ANDROID_INSTRUMENT      ClearWebCoreCache();      ClearWebViewCache();  #if USE(JSC) @@ -1960,9 +1809,6 @@ static void ClearCache(JNIEnv *env, jobject obj)  static jboolean DocumentHasImages(JNIEnv *env, jobject obj)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::NativeCallbackTimeCounter); -#endif      WebCore::Frame* pFrame = GET_NATIVE_FRAME(env, obj);      LOG_ASSERT(pFrame, "DocumentHasImages must take a valid frame pointer!"); @@ -1971,14 +1817,11 @@ static jboolean DocumentHasImages(JNIEnv *env, jobject obj)  static jboolean HasPasswordField(JNIEnv *env, jobject obj)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::NativeCallbackTimeCounter); -#endif      WebCore::Frame* pFrame = GET_NATIVE_FRAME(env, obj);      LOG_ASSERT(pFrame, "HasPasswordField must take a valid frame pointer!");      bool found = false; -    WTF::PassRefPtr<WebCore::HTMLCollection> form = pFrame->document()->forms(); +    WTF::RefPtr<WebCore::HTMLCollection> form = pFrame->document()->forms();      WebCore::Node* node = form->firstItem();      // Null/Empty namespace means that node is not created in HTMLFormElement      // class, but just normal Element class. @@ -2001,9 +1844,6 @@ static jboolean HasPasswordField(JNIEnv *env, jobject obj)  static jobjectArray GetUsernamePassword(JNIEnv *env, jobject obj)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::NativeCallbackTimeCounter); -#endif      WebCore::Frame* pFrame = GET_NATIVE_FRAME(env, obj);      LOG_ASSERT(pFrame, "GetUsernamePassword must take a valid frame pointer!");      jobjectArray strArray = NULL; @@ -2022,16 +1862,13 @@ static jobjectArray GetUsernamePassword(JNIEnv *env, jobject obj)  static void SetUsernamePassword(JNIEnv *env, jobject obj,      jstring username, jstring password)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::NativeCallbackTimeCounter); -#endif      WebCore::Frame* pFrame = GET_NATIVE_FRAME(env, obj);      LOG_ASSERT(pFrame, "SetUsernamePassword must take a valid frame pointer!");      WebCore::HTMLInputElement* usernameEle = NULL;      WebCore::HTMLInputElement* passwordEle = NULL;      bool found = false; -    WTF::PassRefPtr<WebCore::HTMLCollection> form = pFrame->document()->forms(); +    WTF::RefPtr<WebCore::HTMLCollection> form = pFrame->document()->forms();      WebCore::Node* node = form->firstItem();      while (node && !found && !node->namespaceURI().isNull() &&             !node->namespaceURI().isEmpty()) { @@ -2109,11 +1946,8 @@ WebFrame::saveFormData(HTMLFormElement* form)  static void OrientationChanged(JNIEnv *env, jobject obj, int orientation)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::NativeCallbackTimeCounter); -#endif      WebCore::Frame* pFrame = GET_NATIVE_FRAME(env, obj); -    LOGV("Sending orientation: %d", orientation); +    ALOGV("Sending orientation: %d", orientation);      pFrame->sendOrientationChangeEvent(orientation);  } @@ -2127,7 +1961,8 @@ static jboolean GetShouldStartScrolledRight(JNIEnv *env, jobject obj,          RenderStyle* style = document->renderer()->style();          WritingMode writingMode = style->writingMode();          LOG_ASSERT(writingMode != WebCore::BottomToTopWritingMode, -                "BottomToTopWritingMode isn't supported"); +                "BottomToTopWritingMode isn't possible in any " +                "language and cannot be specified in w3c writing-mode.");          if (writingMode == WebCore::RightToLeftWritingMode)              startScrolledRight = true; // vertical-rl pages start scrolled right          else if (writingMode == WebCore::TopToBottomWritingMode) diff --git a/Source/WebKit/android/jni/WebCoreResourceLoader.cpp b/Source/WebKit/android/jni/WebCoreResourceLoader.cpp index f9acc97..3aa4422 100644 --- a/Source/WebKit/android/jni/WebCoreResourceLoader.cpp +++ b/Source/WebKit/android/jni/WebCoreResourceLoader.cpp @@ -34,9 +34,6 @@  #include "ResourceHandleInternal.h"  #include "ResourceResponse.h"  #include "SkUtils.h" -#ifdef ANDROID_INSTRUMENT -#include "TimeCounter.h" -#endif  #include "WebCoreJni.h"  #include <JNIHelp.h> @@ -133,10 +130,6 @@ bool WebCoreResourceLoader::willLoadFromCache(const WebCore::KURL& url, int64_t  // ----------------------------------------------------------------------------  void WebCoreResourceLoader::SetResponseHeader(JNIEnv* env, jobject obj, jint nativeResponse, jstring key, jstring val)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::ResourceTimeCounter); -#endif -          WebCore::ResourceResponse* response = (WebCore::ResourceResponse*)nativeResponse;      LOG_ASSERT(response, "nativeSetResponseHeader must take a valid response pointer!"); @@ -149,20 +142,17 @@ jint WebCoreResourceLoader::CreateResponse(JNIEnv* env, jobject obj, jstring url                                                      jstring statusText, jstring mimeType, jlong expectedLength,                                                      jstring encoding)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::ResourceTimeCounter); -#endif      LOG_ASSERT(url, "Must have a url in the response!");      WebCore::KURL kurl(WebCore::ParsedURLString, jstringToWtfString(env, url));      WTF::String encodingStr;      WTF::String mimeTypeStr;      if (mimeType) {          mimeTypeStr = jstringToWtfString(env, mimeType); -        LOGV("Response setMIMEType: %s", mimeTypeStr.latin1().data()); +        ALOGV("Response setMIMEType: %s", mimeTypeStr.latin1().data());      }      if (encoding) {          encodingStr = jstringToWtfString(env, encoding); -        LOGV("Response setTextEncodingName: %s", encodingStr.latin1().data()); +        ALOGV("Response setTextEncodingName: %s", encodingStr.latin1().data());      }      WebCore::ResourceResponse* response = new WebCore::ResourceResponse(              kurl, mimeTypeStr, (long long)expectedLength, @@ -171,16 +161,13 @@ jint WebCoreResourceLoader::CreateResponse(JNIEnv* env, jobject obj, jstring url      if (statusText) {          WTF::String status = jstringToWtfString(env, statusText);          response->setHTTPStatusText(status); -        LOGV("Response setStatusText: %s", status.latin1().data()); +        ALOGV("Response setStatusText: %s", status.latin1().data());      }      return (int)response;  }  void WebCoreResourceLoader::ReceivedResponse(JNIEnv* env, jobject obj, jint nativeResponse)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::ResourceTimeCounter); -#endif      WebCore::ResourceHandle* handle = GET_NATIVE_HANDLE(env, obj);      LOG_ASSERT(handle, "nativeReceivedResponse must take a valid handle!");      // ResourceLoader::didFail() can set handle to be NULL, we need to check @@ -196,10 +183,7 @@ void WebCoreResourceLoader::ReceivedResponse(JNIEnv* env, jobject obj, jint nati  void WebCoreResourceLoader::AddData(JNIEnv* env, jobject obj, jbyteArray dataArray, jint length)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::ResourceTimeCounter); -#endif -    LOGV("webcore_resourceloader data(%d)", length); +    ALOGV("webcore_resourceloader data(%d)", length);      WebCore::ResourceHandle* handle = GET_NATIVE_HANDLE(env, obj);      LOG_ASSERT(handle, "nativeAddData must take a valid handle!"); @@ -219,10 +203,7 @@ void WebCoreResourceLoader::AddData(JNIEnv* env, jobject obj, jbyteArray dataArr  void WebCoreResourceLoader::Finished(JNIEnv* env, jobject obj)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::ResourceTimeCounter); -#endif -    LOGV("webcore_resourceloader finished"); +    ALOGV("webcore_resourceloader finished");      WebCore::ResourceHandle* handle = GET_NATIVE_HANDLE(env, obj);      LOG_ASSERT(handle, "nativeFinished must take a valid handle!");      // ResourceLoader::didFail() can set handle to be NULL, we need to check @@ -236,10 +217,7 @@ void WebCoreResourceLoader::Finished(JNIEnv* env, jobject obj)  jstring WebCoreResourceLoader::RedirectedToUrl(JNIEnv* env, jobject obj,          jstring baseUrl, jstring redirectTo, jint nativeResponse)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::ResourceTimeCounter); -#endif -    LOGV("webcore_resourceloader redirectedToUrl"); +    ALOGV("webcore_resourceloader redirectedToUrl");      WebCore::ResourceHandle* handle = GET_NATIVE_HANDLE(env, obj);      LOG_ASSERT(handle, "nativeRedirectedToUrl must take a valid handle!");      // ResourceLoader::didFail() can set handle to be NULL, we need to check @@ -275,10 +253,7 @@ jstring WebCoreResourceLoader::RedirectedToUrl(JNIEnv* env, jobject obj,  void WebCoreResourceLoader::Error(JNIEnv* env, jobject obj, jint id, jstring description,          jstring failingUrl)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::ResourceTimeCounter); -#endif -    LOGV("webcore_resourceloader error"); +    ALOGV("webcore_resourceloader error");      WebCore::ResourceHandle* handle = GET_NATIVE_HANDLE(env, obj);      LOG_ASSERT(handle, "nativeError must take a valid handle!");      // ResourceLoader::didFail() can set handle to be NULL, we need to check diff --git a/Source/WebKit/android/jni/WebHistory.cpp b/Source/WebKit/android/jni/WebHistory.cpp index aa74b81..42a7ecf 100644 --- a/Source/WebKit/android/jni/WebHistory.cpp +++ b/Source/WebKit/android/jni/WebHistory.cpp @@ -375,7 +375,7 @@ static void write_string(WTF::Vector<char>& v, const WTF::String& str)          char* data = v.begin() + vectorLen;          // Write the actual string          int l = SkUTF16_ToUTF8(str.characters(), strLen, data); -        LOGV("Writing string       %d %.*s", l, l, data); +        LOG_VERBOSE("Writing string       %d %.*s", l, l, data);          // Go back and write the utf8 length. Subtract sizeof(unsigned) from          // data to get the position to write the length.          memcpy(data - sizeof(unsigned), (char*)&l, sizeof(unsigned)); @@ -417,10 +417,10 @@ static void write_item(WTF::Vector<char>& v, WebCore::HistoryItem* item)      LOG_ASSERT(bridge, "We should have a bridge here!");      // Screen scale      const float scale = bridge->scale(); -    LOGV("Writing scale %f", scale); +    LOG_VERBOSE("Writing scale %f", scale);      v.append((char*)&scale, sizeof(float));      const float textWrapScale = bridge->textWrapScale(); -    LOGV("Writing text wrap scale %f", textWrapScale); +    LOG_VERBOSE("Writing text wrap scale %f", textWrapScale);      v.append((char*)&textWrapScale, sizeof(float));      // Scroll position. @@ -433,19 +433,19 @@ static void write_item(WTF::Vector<char>& v, WebCore::HistoryItem* item)      const WTF::Vector<WTF::String>& docState = item->documentState();      WTF::Vector<WTF::String>::const_iterator end = docState.end();      unsigned stateSize = docState.size(); -    LOGV("Writing docState     %d", stateSize); +    LOG_VERBOSE("Writing docState     %d", stateSize);      v.append((char*)&stateSize, sizeof(unsigned));      for (WTF::Vector<WTF::String>::const_iterator i = docState.begin(); i != end; ++i) {          write_string(v, *i);      }      // Is target item -    LOGV("Writing isTargetItem %d", item->isTargetItem()); +    LOG_VERBOSE("Writing isTargetItem %d", item->isTargetItem());      v.append((char)item->isTargetItem());      // Children count      unsigned childCount = item->children().size(); -    LOGV("Writing childCount   %d", childCount); +    LOG_VERBOSE("Writing childCount   %d", childCount);      v.append((char*)&childCount, sizeof(unsigned));  } @@ -490,12 +490,12 @@ static bool read_item_recursive(WebCore::HistoryItem* newItem,      // Read the original url      // Read the expected length of the string. -    unsigned l; +    size_t l;      memcpy(&l, data, sizeofUnsigned);      // Increment data pointer by the size of an unsigned int.      data += sizeofUnsigned;      if (l) { -        LOGV("Original url    %d %.*s", l, l, data); +        LOG_VERBOSE("Original url    %d %.*s", l, l, data);          // If we have a length, check if that length exceeds the data length          // and return null if there is not enough data.          if (data + l < end) @@ -513,7 +513,7 @@ static bool read_item_recursive(WebCore::HistoryItem* newItem,      memcpy(&l, data, sizeofUnsigned);      data += sizeofUnsigned;      if (l) { -        LOGV("Url             %d %.*s", l, l, data); +        LOG_VERBOSE("Url             %d %.*s", l, l, data);          if (data + l < end)              newItem->setURLString(e.decode(data, l));          else @@ -527,7 +527,7 @@ static bool read_item_recursive(WebCore::HistoryItem* newItem,      memcpy(&l, data, sizeofUnsigned);      data += sizeofUnsigned;      if (l) { -        LOGV("Title           %d %.*s", l, l, data); +        LOG_VERBOSE("Title           %d %.*s", l, l, data);          if (data + l < end)              newItem->setTitle(e.decode(data, l));          else @@ -539,13 +539,13 @@ static bool read_item_recursive(WebCore::HistoryItem* newItem,      // Generate a new ResourceRequest object for populating form information.      WTF::String formContentType; -    WTF::PassRefPtr<WebCore::FormData> formData = NULL; +    WTF::RefPtr<WebCore::FormData> formData = NULL;      // Read the form content type      memcpy(&l, data, sizeofUnsigned);      data += sizeofUnsigned;      if (l) { -        LOGV("Content type    %d %.*s", l, l, data); +        LOG_VERBOSE("Content type    %d %.*s", l, l, data);          if (data + l < end)              formContentType = e.decode(data, l);          else @@ -559,7 +559,7 @@ static bool read_item_recursive(WebCore::HistoryItem* newItem,      memcpy(&l, data, sizeofUnsigned);      data += sizeofUnsigned;      if (l) { -        LOGV("Form data       %d %.*s", l, l, data); +        LOG_VERBOSE("Form data       %d %.*s", l, l, data);          if (data + l < end)              formData = WebCore::FormData::create(data, l);          else @@ -591,7 +591,7 @@ static bool read_item_recursive(WebCore::HistoryItem* newItem,      memcpy(&l, data, sizeofUnsigned);      data += sizeofUnsigned;      if (l) { -        LOGV("Target          %d %.*s", l, l, data); +        LOG_VERBOSE("Target          %d %.*s", l, l, data);          if (data + l < end)              newItem->setTarget(e.decode(data, l));          else @@ -606,11 +606,11 @@ static bool read_item_recursive(WebCore::HistoryItem* newItem,      float fValue;      // Read the screen scale      memcpy(&fValue, data, sizeof(float)); -    LOGV("Screen scale    %f", fValue); +    LOG_VERBOSE("Screen scale    %f", fValue);      bridge->setScale(fValue);      data += sizeof(float);      memcpy(&fValue, data, sizeofUnsigned); -    LOGV("Text wrap scale    %f", fValue); +    LOG_VERBOSE("Text wrap scale    %f", fValue);      bridge->setTextWrapScale(fValue);      data += sizeof(float); @@ -631,7 +631,7 @@ static bool read_item_recursive(WebCore::HistoryItem* newItem,      // Read the document state      memcpy(&l, data, sizeofUnsigned); -    LOGV("Document state  %d", l); +    LOG_VERBOSE("Document state  %d", l);      data += sizeofUnsigned;      if (l) {          // Check if we have enough data to at least parse the sizes of each @@ -653,7 +653,7 @@ static bool read_item_recursive(WebCore::HistoryItem* newItem,                  docState.append(e.decode(data, strLen));              else                  return false; -            LOGV("\t\t%d %.*s", strLen, strLen, data); +            LOG_VERBOSE("\t\t%d %.*s", strLen, strLen, data);              data += strLen;          }          newItem->setDocumentState(docState); @@ -668,7 +668,7 @@ static bool read_item_recursive(WebCore::HistoryItem* newItem,      unsigned char c = (unsigned char)data[0];      if (c > 1)          return false; -    LOGV("Target item     %d", c); +    LOG_VERBOSE("Target item     %d", c);      newItem->setIsTargetItem((bool)c);      data++;      if (end - data < sizeofUnsigned) @@ -676,7 +676,7 @@ static bool read_item_recursive(WebCore::HistoryItem* newItem,      // Read the child count      memcpy(&l, data, sizeofUnsigned); -    LOGV("Child count     %d", l); +    LOG_VERBOSE("Child count     %d", l);      data += sizeofUnsigned;      *pData = data;      if (l) { @@ -686,7 +686,7 @@ static bool read_item_recursive(WebCore::HistoryItem* newItem,          while (l--) {              // No need to check the length each time because read_item_recursive              // will return null if there isn't enough data left to parse. -            WTF::PassRefPtr<WebCore::HistoryItem> child = WebCore::HistoryItem::create(); +            WTF::RefPtr<WebCore::HistoryItem> child = WebCore::HistoryItem::create();              // Set a bridge that will not call into java.              child->setBridge(new WebHistoryItem(static_cast<WebHistoryItem*>(bridge)));              // Read the child item. diff --git a/Source/WebKit/android/jni/WebIconDatabase.cpp b/Source/WebKit/android/jni/WebIconDatabase.cpp index d5f8947..e46b600 100644 --- a/Source/WebKit/android/jni/WebIconDatabase.cpp +++ b/Source/WebKit/android/jni/WebIconDatabase.cpp @@ -185,7 +185,7 @@ static void Open(JNIEnv* env, jobject obj, jstring path)          }      }      if (didSetPermissions) { -        LOGV("Opening WebIconDatabase file '%s'", pathStr.latin1().data()); +        ALOGV("Opening WebIconDatabase file '%s'", pathStr.latin1().data());          bool res = iconDb.open(pathStr, WebCore::IconDatabase::defaultDatabaseFilename());          if (!res)              LOGE("Open failed!"); @@ -200,7 +200,7 @@ static void Close(JNIEnv* env, jobject obj)  static void RemoveAllIcons(JNIEnv* env, jobject obj)  { -    LOGV("Removing all icons"); +    ALOGV("Removing all icons");      WebCore::iconDatabase().removeAllIcons();  } @@ -212,7 +212,7 @@ static jobject IconForPageUrl(JNIEnv* env, jobject obj, jstring url)      // FIXME: This method should not be used from outside WebCore and will be removed.      // http://trac.webkit.org/changeset/81484      WebCore::Image* icon = WebCore::iconDatabase().synchronousIconForPageURL(urlStr, WebCore::IntSize(16, 16)); -    LOGV("Retrieving icon for '%s' %p", urlStr.latin1().data(), icon); +    ALOGV("Retrieving icon for '%s' %p", urlStr.latin1().data(), icon);      return webcoreImageToJavaBitmap(env, icon);  } @@ -221,7 +221,7 @@ static void RetainIconForPageUrl(JNIEnv* env, jobject obj, jstring url)      LOG_ASSERT(url, "No url given to retainIconForPageUrl");      WTF::String urlStr = jstringToWtfString(env, url); -    LOGV("Retaining icon for '%s'", urlStr.latin1().data()); +    ALOGV("Retaining icon for '%s'", urlStr.latin1().data());      WebCore::iconDatabase().retainIconForPageURL(urlStr);  } @@ -230,7 +230,7 @@ static void ReleaseIconForPageUrl(JNIEnv* env, jobject obj, jstring url)      LOG_ASSERT(url, "No url given to releaseIconForPageUrl");      WTF::String urlStr = jstringToWtfString(env, url); -    LOGV("Releasing icon for '%s'", urlStr.latin1().data()); +    ALOGV("Releasing icon for '%s'", urlStr.latin1().data());      WebCore::iconDatabase().releaseIconForPageURL(urlStr);  } diff --git a/Source/WebKit/android/jni/WebViewCore.cpp b/Source/WebKit/android/jni/WebViewCore.cpp index 839c352..48eefed 100644 --- a/Source/WebKit/android/jni/WebViewCore.cpp +++ b/Source/WebKit/android/jni/WebViewCore.cpp @@ -131,7 +131,6 @@  #if USE(V8)  #include "ScriptController.h" -#include "V8Counters.h"  #include <wtf/text/CString.h>  #endif @@ -152,10 +151,6 @@ FILE* gDomTreeFile = 0;  FILE* gRenderTreeFile = 0;  #endif -#ifdef ANDROID_INSTRUMENT -#include "TimeCounter.h" -#endif -  #if USE(ACCELERATED_COMPOSITING)  #include "GraphicsLayerAndroid.h"  #include "RenderLayerCompositor.h" @@ -588,11 +583,6 @@ void WebViewCore::recordPictureSet(PictureSet* content)      if (!success)          return; -    {   // collect WebViewCoreRecordTimeCounter after layoutIfNeededRecursive -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreRecordTimeCounter); -#endif -      // if the webkit page dimensions changed, discard the pictureset and redraw.      WebCore::FrameView* view = m_mainFrame->view();      int width = view->contentsWidth(); @@ -710,8 +700,6 @@ void WebViewCore::recordPictureSet(PictureSet* content)      }  #endif -    } // WebViewCoreRecordTimeCounter -      WebCore::Node* oldFocusNode = currentFocus();      m_frameCacheOutOfDate = true;      WebCore::IntRect oldBounds; @@ -1094,7 +1082,7 @@ void WebViewCore::didFirstLayout()      const WebCore::KURL& url = m_mainFrame->document()->url();      if (url.isEmpty())          return; -    LOGV("::WebCore:: didFirstLayout %s", url.string().ascii().data()); +    ALOGV("::WebCore:: didFirstLayout %s", url.string().ascii().data());      WebCore::FrameLoadType loadType = m_mainFrame->loader()->loadType(); @@ -1606,9 +1594,6 @@ void WebViewCore::updateFrameCache()          LOGW("updateFrameCache: pending style recalc, ignoring.");          return;      } -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreBuildNavTimeCounter); -#endif      m_frameCacheOutOfDate = false;      m_temp = new CachedRoot();      m_temp->init(m_mainFrame, &m_history); @@ -2240,7 +2225,7 @@ String WebViewCore::modifySelectionTextNavigationAxis(DOMSelection* selection, i          if (m_currentNodeDomNavigationAxis                  && CacheBuilder::validNode(m_mainFrame,                  m_mainFrame, m_currentNodeDomNavigationAxis)) { -            PassRefPtr<Range> rangeRef = +            RefPtr<Range> rangeRef =                  selection->frame()->document()->createRange();              rangeRef->selectNode(m_currentNodeDomNavigationAxis, ec);              m_currentNodeDomNavigationAxis = 0; @@ -2252,7 +2237,7 @@ String WebViewCore::modifySelectionTextNavigationAxis(DOMSelection* selection, i          } else if (m_cursorNode                  && CacheBuilder::validNode(m_mainFrame,                  m_mainFrame, m_cursorNode)) { -            PassRefPtr<Range> rangeRef = +            RefPtr<Range> rangeRef =                  selection->frame()->document()->createRange();              rangeRef->selectNode(reinterpret_cast<Node*>(m_cursorNode), ec);              if (ec) @@ -2456,13 +2441,13 @@ String WebViewCore::modifySelectionTextNavigationAxis(DOMSelection* selection, i          scrollNodeIntoView(m_mainFrame, selection->anchorNode());      // format markup for the visible content -    PassRefPtr<Range> range = selection->getRangeAt(0, ec); +    RefPtr<Range> range = selection->getRangeAt(0, ec);      if (ec)          return String();      IntRect bounds = range->boundingBox();      selectAt(bounds.center().x(), bounds.center().y());      markup = formatMarkup(selection); -    LOGV("Selection markup: %s", markup.utf8().data()); +    ALOGV("Selection markup: %s", markup.utf8().data());      return markup;  } @@ -2721,7 +2706,7 @@ String WebViewCore::modifySelectionDomNavigationAxis(DOMSelection* selection, in          m_currentNodeDomNavigationAxis = currentNode;          scrollNodeIntoView(m_mainFrame, currentNode);          String selectionString = createMarkup(currentNode); -        LOGV("Selection markup: %s", selectionString.utf8().data()); +        ALOGV("Selection markup: %s", selectionString.utf8().data());          return selectionString;      }      return String(); @@ -2783,7 +2768,7 @@ String WebViewCore::formatMarkup(DOMSelection* selection)  {      ExceptionCode ec = 0;      String markup = String(); -    PassRefPtr<Range> wholeRange = selection->getRangeAt(0, ec); +    RefPtr<Range> wholeRange = selection->getRangeAt(0, ec);      if (ec)          return String();      if (!wholeRange->startContainer() || !wholeRange->startContainer()) @@ -2793,7 +2778,7 @@ String WebViewCore::formatMarkup(DOMSelection* selection)      Node* firstNode = wholeRange->firstNode();      Node* pastLastNode = wholeRange->pastLastNode();      Node* currentNode = firstNode; -    PassRefPtr<Range> currentRange; +    RefPtr<Range> currentRange;      while (currentNode != pastLastNode) {          Node* nextNode = currentNode->traverseNextNode(); @@ -3944,9 +3929,6 @@ static jstring RequestLabel(JNIEnv *env, jobject obj, int framePointer,  static void ClearContent(JNIEnv *env, jobject obj)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif      WebViewCore* viewImpl = GET_NATIVE_VIEW(env, obj);      viewImpl->clearContent();  } @@ -3960,11 +3942,8 @@ static void SetSize(JNIEnv *env, jobject obj, jint width, jint height,          jint textWrapWidth, jfloat scale, jint screenWidth, jint screenHeight,          jint anchorX, jint anchorY, jboolean ignoreHeight)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif      WebViewCore* viewImpl = GET_NATIVE_VIEW(env, obj); -    LOGV("webviewcore::nativeSetSize(%u %u)\n viewImpl: %p", (unsigned)width, (unsigned)height, viewImpl); +    ALOGV("webviewcore::nativeSetSize(%u %u)\n viewImpl: %p", (unsigned)width, (unsigned)height, viewImpl);      LOG_ASSERT(viewImpl, "viewImpl not set in nativeSetSize");      viewImpl->setSizeScreenWidthAndScale(width, height, textWrapWidth, scale,              screenWidth, screenHeight, anchorX, anchorY, ignoreHeight); @@ -3972,9 +3951,6 @@ static void SetSize(JNIEnv *env, jobject obj, jint width, jint height,  static void SetScrollOffset(JNIEnv *env, jobject obj, jint gen, jboolean sendScrollEvent, jint x, jint y)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif      WebViewCore* viewImpl = GET_NATIVE_VIEW(env, obj);      LOG_ASSERT(viewImpl, "need viewImpl"); @@ -3984,9 +3960,6 @@ static void SetScrollOffset(JNIEnv *env, jobject obj, jint gen, jboolean sendScr  static void SetGlobalBounds(JNIEnv *env, jobject obj, jint x, jint y, jint h,                              jint v)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif      WebViewCore* viewImpl = GET_NATIVE_VIEW(env, obj);      LOG_ASSERT(viewImpl, "need viewImpl"); @@ -3997,18 +3970,12 @@ static jboolean Key(JNIEnv *env, jobject obj, jint keyCode, jint unichar,          jint repeatCount, jboolean isShift, jboolean isAlt, jboolean isSym,          jboolean isDown)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif      return GET_NATIVE_VIEW(env, obj)->key(PlatformKeyboardEvent(keyCode,          unichar, repeatCount, isDown, isShift, isAlt, isSym));  }  static void Click(JNIEnv *env, jobject obj, int framePtr, int nodePtr, jboolean fake)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif      WebViewCore* viewImpl = GET_NATIVE_VIEW(env, obj);      LOG_ASSERT(viewImpl, "viewImpl not set in Click"); @@ -4024,27 +3991,18 @@ static void ContentInvalidateAll(JNIEnv *env, jobject obj)  static void DeleteSelection(JNIEnv *env, jobject obj, jint start, jint end,          jint textGeneration)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif      WebViewCore* viewImpl = GET_NATIVE_VIEW(env, obj);      viewImpl->deleteSelection(start, end, textGeneration);  }  static void SetSelection(JNIEnv *env, jobject obj, jint start, jint end)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif      WebViewCore* viewImpl = GET_NATIVE_VIEW(env, obj);      viewImpl->setSelection(start, end);  }  static jstring ModifySelection(JNIEnv *env, jobject obj, jint direction, jint granularity)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif      WebViewCore* viewImpl = GET_NATIVE_VIEW(env, obj);      String selectionString = viewImpl->modifySelection(direction, granularity);      return wtfStringToJstring(env, selectionString); @@ -4054,9 +4012,6 @@ static void ReplaceTextfieldText(JNIEnv *env, jobject obj,      jint oldStart, jint oldEnd, jstring replace, jint start, jint end,      jint textGeneration)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif      WebViewCore* viewImpl = GET_NATIVE_VIEW(env, obj);      WTF::String webcoreString = jstringToWtfString(env, replace);      viewImpl->replaceTextfieldText(oldStart, @@ -4067,9 +4022,6 @@ static void PassToJs(JNIEnv *env, jobject obj,      jint generation, jstring currentText, jint keyCode,      jint keyValue, jboolean down, jboolean cap, jboolean fn, jboolean sym)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif      WTF::String current = jstringToWtfString(env, currentText);      GET_NATIVE_VIEW(env, obj)->passToJs(generation, current,          PlatformKeyboardEvent(keyCode, keyValue, 0, down, cap, fn, sym)); @@ -4078,19 +4030,13 @@ static void PassToJs(JNIEnv *env, jobject obj,  static void ScrollFocusedTextInput(JNIEnv *env, jobject obj, jfloat xPercent,      jint y)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif      WebViewCore* viewImpl = GET_NATIVE_VIEW(env, obj);      viewImpl->scrollFocusedTextInput(xPercent, y);  }  static void SetFocusControllerActive(JNIEnv *env, jobject obj, jboolean active)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif -    LOGV("webviewcore::nativeSetFocusControllerActive()\n"); +    ALOGV("webviewcore::nativeSetFocusControllerActive()\n");      WebViewCore* viewImpl = GET_NATIVE_VIEW(env, obj);      LOG_ASSERT(viewImpl, "viewImpl not set in nativeSetFocusControllerActive");      viewImpl->setFocusControllerActive(active); @@ -4098,10 +4044,7 @@ static void SetFocusControllerActive(JNIEnv *env, jobject obj, jboolean active)  static void SaveDocumentState(JNIEnv *env, jobject obj, jint frame)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif -    LOGV("webviewcore::nativeSaveDocumentState()\n"); +    ALOGV("webviewcore::nativeSaveDocumentState()\n");      WebViewCore* viewImpl = GET_NATIVE_VIEW(env, obj);      LOG_ASSERT(viewImpl, "viewImpl not set in nativeSaveDocumentState");      viewImpl->saveDocumentState((WebCore::Frame*) frame); @@ -4133,9 +4076,6 @@ static void NotifyAnimationStarted(JNIEnv *env, jobject obj, jint nativeClass)  static jint RecordContent(JNIEnv *env, jobject obj, jobject region, jobject pt)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif      WebViewCore* viewImpl = GET_NATIVE_VIEW(env, obj);      SkRegion* nativeRegion = GraphicsJNI::getNativeRegion(env, region);      SkIPoint nativePt; @@ -4146,18 +4086,12 @@ static jint RecordContent(JNIEnv *env, jobject obj, jobject region, jobject pt)  static void SplitContent(JNIEnv *env, jobject obj, jint content)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif      WebViewCore* viewImpl = GET_NATIVE_VIEW(env, obj);      viewImpl->splitContent(reinterpret_cast<PictureSet*>(content));  }  static void SendListBoxChoice(JNIEnv* env, jobject obj, jint choice)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif      WebViewCore* viewImpl = GET_NATIVE_VIEW(env, obj);      LOG_ASSERT(viewImpl, "viewImpl not set in nativeSendListBoxChoice");      viewImpl->popupReply(choice); @@ -4172,9 +4106,6 @@ static void SendListBoxChoice(JNIEnv* env, jobject obj, jint choice)  static void SendListBoxChoices(JNIEnv* env, jobject obj, jbooleanArray jArray,          jint size)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif      WebViewCore* viewImpl = GET_NATIVE_VIEW(env, obj);      LOG_ASSERT(viewImpl, "viewImpl not set in nativeSendListBoxChoices");      jboolean* ptrArray = env->GetBooleanArrayElements(jArray, 0); @@ -4193,9 +4124,6 @@ static void SendListBoxChoices(JNIEnv* env, jobject obj, jbooleanArray jArray,  static jstring FindAddress(JNIEnv *env, jobject obj, jstring addr,      jboolean caseInsensitive)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif      if (!addr)          return 0;      int length = env->GetStringLength(addr); @@ -4216,9 +4144,6 @@ static jboolean HandleTouchEvent(JNIEnv *env, jobject obj, jint action, jintArra                                   jintArray xArray, jintArray yArray,                                   jint count, jint actionIndex, jint metaState)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif      WebViewCore* viewImpl = GET_NATIVE_VIEW(env, obj);      LOG_ASSERT(viewImpl, "viewImpl not set in %s", __FUNCTION__);      jint* ptrIdArray = env->GetIntArrayElements(idArray, 0); @@ -4241,9 +4166,6 @@ static jboolean HandleTouchEvent(JNIEnv *env, jobject obj, jint action, jintArra  static void TouchUp(JNIEnv *env, jobject obj, jint touchGeneration,          jint frame, jint node, jint x, jint y)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif      WebViewCore* viewImpl = GET_NATIVE_VIEW(env, obj);      LOG_ASSERT(viewImpl, "viewImpl not set in %s", __FUNCTION__);      viewImpl->touchUp(touchGeneration, @@ -4252,9 +4174,6 @@ static void TouchUp(JNIEnv *env, jobject obj, jint touchGeneration,  static jstring RetrieveHref(JNIEnv *env, jobject obj, jint x, jint y)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif      WebViewCore* viewImpl = GET_NATIVE_VIEW(env, obj);      LOG_ASSERT(viewImpl, "viewImpl not set in %s", __FUNCTION__);      WTF::String result = viewImpl->retrieveHref(x, y); @@ -4265,9 +4184,6 @@ static jstring RetrieveHref(JNIEnv *env, jobject obj, jint x, jint y)  static jstring RetrieveAnchorText(JNIEnv *env, jobject obj, jint x, jint y)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif      WebViewCore* viewImpl = GET_NATIVE_VIEW(env, obj);      LOG_ASSERT(viewImpl, "viewImpl not set in %s", __FUNCTION__);      WTF::String result = viewImpl->retrieveAnchorText(x, y); @@ -4289,9 +4205,6 @@ static void StopPaintingCaret(JNIEnv *env, jobject obj)  static void MoveFocus(JNIEnv *env, jobject obj, jint framePtr, jint nodePtr)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif      WebViewCore* viewImpl = GET_NATIVE_VIEW(env, obj);      LOG_ASSERT(viewImpl, "viewImpl not set in %s", __FUNCTION__);      viewImpl->moveFocus((WebCore::Frame*) framePtr, (WebCore::Node*) nodePtr); @@ -4300,9 +4213,6 @@ static void MoveFocus(JNIEnv *env, jobject obj, jint framePtr, jint nodePtr)  static void MoveMouse(JNIEnv *env, jobject obj, jint frame,          jint x, jint y)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif      WebViewCore* viewImpl = GET_NATIVE_VIEW(env, obj);      LOG_ASSERT(viewImpl, "viewImpl not set in %s", __FUNCTION__);      viewImpl->moveMouse((WebCore::Frame*) frame, x, y); @@ -4311,9 +4221,6 @@ static void MoveMouse(JNIEnv *env, jobject obj, jint frame,  static void MoveMouseIfLatest(JNIEnv *env, jobject obj, jint moveGeneration,          jint frame, jint x, jint y)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif      WebViewCore* viewImpl = GET_NATIVE_VIEW(env, obj);      LOG_ASSERT(viewImpl, "viewImpl not set in %s", __FUNCTION__);      viewImpl->moveMouseIfLatest(moveGeneration, @@ -4322,9 +4229,6 @@ static void MoveMouseIfLatest(JNIEnv *env, jobject obj, jint moveGeneration,  static void UpdateFrameCache(JNIEnv *env, jobject obj)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif      WebViewCore* viewImpl = GET_NATIVE_VIEW(env, obj);      LOG_ASSERT(viewImpl, "viewImpl not set in %s", __FUNCTION__);      viewImpl->updateFrameCache(); @@ -4332,9 +4236,6 @@ static void UpdateFrameCache(JNIEnv *env, jobject obj)  static jint GetContentMinPrefWidth(JNIEnv *env, jobject obj)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif      WebViewCore* viewImpl = GET_NATIVE_VIEW(env, obj);      LOG_ASSERT(viewImpl, "viewImpl not set in %s", __FUNCTION__); @@ -4353,9 +4254,6 @@ static jint GetContentMinPrefWidth(JNIEnv *env, jobject obj)  static void SetViewportSettingsFromNative(JNIEnv *env, jobject obj)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif      WebViewCore* viewImpl = GET_NATIVE_VIEW(env, obj);      LOG_ASSERT(viewImpl, "viewImpl not set in %s", __FUNCTION__); @@ -4376,9 +4274,6 @@ static void SetViewportSettingsFromNative(JNIEnv *env, jobject obj)  static void SetBackgroundColor(JNIEnv *env, jobject obj, jint color)  { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif      WebViewCore* viewImpl = GET_NATIVE_VIEW(env, obj);      LOG_ASSERT(viewImpl, "viewImpl not set in %s", __FUNCTION__); @@ -4409,15 +4304,6 @@ static void DumpNavTree(JNIEnv *env, jobject obj)      viewImpl->dumpNavTree();  } -static void DumpV8Counters(JNIEnv*, jobject) -{ -#if USE(V8) -#ifdef ANDROID_INSTRUMENT -    V8Counters::dumpCounters(); -#endif -#endif -} -  static void SetJsFlags(JNIEnv *env, jobject obj, jstring flags)  {  #if USE(V8) @@ -4453,9 +4339,6 @@ static void GeolocationPermissionsProvide(JNIEnv* env, jobject obj, jstring orig  }  static void RegisterURLSchemeAsLocal(JNIEnv* env, jobject obj, jstring scheme) { -#ifdef ANDROID_INSTRUMENT -    TimeCounterAuto counter(TimeCounter::WebViewCoreTimeCounter); -#endif      WebCore::SchemeRegistry::registerURLSchemeAsLocal(jstringToWtfString(env, scheme));  } @@ -4730,8 +4613,6 @@ static JNINativeMethod gJavaWebViewCoreMethods[] = {          (void*) DumpRenderTree },      { "nativeDumpNavTree", "()V",          (void*) DumpNavTree }, -    { "nativeDumpV8Counters", "()V", -        (void*) DumpV8Counters },      { "nativeSetNewStorageLimit", "(J)V",          (void*) SetNewStorageLimit },      { "nativeGeolocationPermissionsProvide", "(Ljava/lang/String;ZZ)V", diff --git a/Source/WebKit/android/nav/WebView.cpp b/Source/WebKit/android/nav/WebView.cpp index 76f0fb8..5e943ae 100644 --- a/Source/WebKit/android/nav/WebView.cpp +++ b/Source/WebKit/android/nav/WebView.cpp @@ -53,9 +53,6 @@  #include "SkPicture.h"  #include "SkRect.h"  #include "SkTime.h" -#ifdef ANDROID_INSTRUMENT -#include "TimeCounter.h" -#endif  #include "TilesManager.h"  #include "WebCoreJni.h"  #include "WebRequestContext.h" @@ -134,7 +131,6 @@ struct JavaGlue {      jmethodID   m_viewInvalidateRect;      jmethodID   m_postInvalidateDelayed;      jmethodID   m_pageSwapCallback; -    jmethodID   m_inFullScreenMode;      jfieldID    m_rectLeft;      jfieldID    m_rectTop;      jmethodID   m_rectWidth; @@ -173,7 +169,6 @@ WebView(JNIEnv* env, jobject javaWebView, int viewImpl, WTF::String drawableDir,      m_javaGlue.m_postInvalidateDelayed = GetJMethod(env, clazz,          "viewInvalidateDelayed", "(JIIII)V");      m_javaGlue.m_pageSwapCallback = GetJMethod(env, clazz, "pageSwapCallback", "(Z)V"); -    m_javaGlue.m_inFullScreenMode = GetJMethod(env, clazz, "inFullScreenMode", "()Z");      m_javaGlue.m_getTextHandleScale = GetJMethod(env, clazz, "getTextHandleScale", "()F");      env->DeleteLocalRef(clazz); @@ -451,7 +446,7 @@ bool drawGL(WebCore::IntRect& viewRect, WebCore::IntRect* invalRect,          WebCore::IntRect& clip, float scale, int extras)  {  #if USE(ACCELERATED_COMPOSITING) -    if (!m_baseLayer || inFullScreenMode()) +    if (!m_baseLayer)          return false;      if (!m_glWebViewState) { @@ -1403,17 +1398,6 @@ void postInvalidateDelayed(int64_t delay, const WebCore::IntRect& bounds)      checkException(env);  } -bool inFullScreenMode() -{ -    JNIEnv* env = JSC::Bindings::getJNIEnv(); -    AutoJObject javaObject = m_javaGlue.object(env); -    if (!javaObject.get()) -        return false; -    jboolean result = env->CallBooleanMethod(javaObject.get(), m_javaGlue.m_inFullScreenMode); -    checkException(env); -    return result; -} -  int moveGeneration()  {      return m_viewImpl->m_moveGeneration; @@ -1566,8 +1550,7 @@ class GLDrawFunctor : Functor {      public:      GLDrawFunctor(WebView* _wvInstance,              bool(WebView::*_funcPtr)(WebCore::IntRect&, WebCore::IntRect*, -                    WebCore::IntRect&, int, WebCore::IntRect&, -                    jfloat, jint), +                    WebCore::IntRect&, int, WebCore::IntRect&, jfloat, jint),              WebCore::IntRect _viewRect, float _scale, int _extras) {          wvInstance = _wvInstance;          funcPtr = _funcPtr; @@ -2153,13 +2136,6 @@ static void nativeHideCursor(JNIEnv *env, jobject obj)      view->hideCursor();  } -static void nativeInstrumentReport(JNIEnv *env, jobject obj) -{ -#ifdef ANDROID_INSTRUMENT -    TimeCounter::reportNow(); -#endif -} -  static void nativeSelectBestAt(JNIEnv *env, jobject obj, jobject jrect)  {      WebView* view = GET_NATIVE_VIEW(env, obj); @@ -2838,8 +2814,6 @@ static JNINativeMethod gJavaWebViewMethods[] = {          (void*) nativeHitSelection },      { "nativeImageURI", "(II)Ljava/lang/String;",          (void*) nativeImageURI }, -    { "nativeInstrumentReport", "()V", -        (void*) nativeInstrumentReport },      { "nativeLayerBounds", "(I)Landroid/graphics/Rect;",          (void*) nativeLayerBounds },      { "nativeMotionUp", "(III)Z", diff --git a/Source/WebKit/android/wds/client/AdbConnection.cpp b/Source/WebKit/android/wds/client/AdbConnection.cpp index 465f9c3..617ed72 100644 --- a/Source/WebKit/android/wds/client/AdbConnection.cpp +++ b/Source/WebKit/android/wds/client/AdbConnection.cpp @@ -89,7 +89,7 @@ bool AdbConnection::sendRequest(const char* fmt, ...) const {      int res = vsnprintf(buf, MAX_COMMAND_LENGTH, fmt, args);      va_end(args); -    LOGV("Sending command: %04X%.*s", res, res, buf); +    ALOGV("Sending command: %04X%.*s", res, res, buf);      // Construct the payload length      char payloadLen[PAYLOAD_LENGTH + 1]; @@ -156,7 +156,7 @@ bool AdbConnection::checkOkayResponse() const {      // Check for a response other than OKAY/FAIL      if ((res == ADB_RESPONSE_LENGTH) && (strncmp(buf, "OKAY", res) == 0)) { -        LOGV("Command OKAY"); +        ALOGV("Command OKAY");          return true;      } else if (strncmp(buf, "FAIL", ADB_RESPONSE_LENGTH) == 0) {          // Something happened, print out the reason for failure @@ -224,7 +224,7 @@ const DeviceList& AdbConnection::getDeviceList() {          static const char emulator[] = "emulator-";          if (strncmp(serial, emulator, sizeof(emulator) - 1) == 0)              t = Device::EMULATOR; -        LOGV("Adding device %s (%s)", serial, state); +        ALOGV("Adding device %s (%s)", serial, state);          m_devices.add(new Device(serial, t, this));          // Reset for the next line diff --git a/Source/WebKit/android/wds/client/main.cpp b/Source/WebKit/android/wds/client/main.cpp index 1c7d856..7e96f30 100644 --- a/Source/WebKit/android/wds/client/main.cpp +++ b/Source/WebKit/android/wds/client/main.cpp @@ -141,7 +141,7 @@ int main(int argc, char** argv) {          return 1;      } -    LOGV("Connecting to localhost port " PORT_STR); +    ALOGV("Connecting to localhost port " PORT_STR);      const char* command = argv[optind];      int commandLen = strlen(command); | 
