diff options
author | japhet@chromium.org <japhet@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-06-15 18:24:47 +0000 |
---|---|---|
committer | japhet@chromium.org <japhet@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-06-15 18:24:47 +0000 |
commit | 055a9406124ab9642e444d07fad1b98b1485bf86 (patch) | |
tree | 6f05997004c1da04fa1ad42cede286549d366109 | |
parent | 045e9351159d84a721016c3fc570f9de7d546895 (diff) | |
download | chromium_src-055a9406124ab9642e444d07fad1b98b1485bf86.zip chromium_src-055a9406124ab9642e444d07fad1b98b1485bf86.tar.gz chromium_src-055a9406124ab9642e444d07fad1b98b1485bf86.tar.bz2 |
Use V8 bindings for V8CustomXPathNSResolver in svn.webkit.org
Review URL: http://codereview.chromium.org/118329
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@18407 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | webkit/port/bindings/v8/JSXPathNSResolver.cpp | 90 | ||||
-rw-r--r-- | webkit/port/bindings/v8/JSXPathNSResolver.h | 33 | ||||
-rw-r--r-- | webkit/webkit.gyp | 2 |
3 files changed, 0 insertions, 125 deletions
diff --git a/webkit/port/bindings/v8/JSXPathNSResolver.cpp b/webkit/port/bindings/v8/JSXPathNSResolver.cpp deleted file mode 100644 index 5174809..0000000 --- a/webkit/port/bindings/v8/JSXPathNSResolver.cpp +++ /dev/null @@ -1,90 +0,0 @@ -// Copyright (c) 2008, Google Inc. -// All rights reserved. -// -// Redistribution and use in source and binary forms, with or without -// modification, are permitted provided that the following conditions are -// met: -// -// * 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. -// * Neither the name of Google Inc. nor the names of its -// contributors may be used to endorse or promote products derived from -// this software without specific prior written permission. -// -// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -#include "config.h" -#include "JSXPathNSResolver.h" - -#if ENABLE(XPATH) - -#include "v8_proxy.h" -#include "v8_binding.h" -#include "PlatformString.h" - -namespace WebCore { - -JSXPathNSResolver::JSXPathNSResolver(v8::Handle<v8::Object> resolver) -: m_resolver(resolver) { -} - -JSXPathNSResolver::~JSXPathNSResolver() { -} - -String JSXPathNSResolver::lookupNamespaceURI(const String& prefix) { - v8::Handle<v8::Function> lookupNamespaceURIFunc; - v8::Handle<v8::String> lookupNamespaceURIName = v8::String::New("lookupNamespaceURI"); - - // Check if the resolver has a function property named lookupNamespaceURI. - if (m_resolver->Has(lookupNamespaceURIName)) { - v8::Handle<v8::Value> lookupNamespaceURI = m_resolver->Get(lookupNamespaceURIName); - if (lookupNamespaceURI->IsFunction()) { - lookupNamespaceURIFunc = v8::Handle<v8::Function>::Cast(lookupNamespaceURI); - } - } - - if (lookupNamespaceURIFunc.IsEmpty() && !m_resolver->IsFunction()) { - Frame* frame = V8Proxy::retrieveFrameForEnteredContext(); - log_info(frame, "XPathNSResolver does not have a lookupNamespaceURI method.", String()); - return String(); - } - - // Catch exceptions from calling the namespace resolver. - v8::TryCatch try_catch; - try_catch.SetVerbose(true); // Print exceptions to console. - - const int argc = 1; - v8::Handle<v8::Value> argv[argc] = { v8String(prefix) }; - v8::Handle<v8::Function> function = lookupNamespaceURIFunc.IsEmpty() - ? v8::Handle<v8::Function>::Cast(m_resolver) - : lookupNamespaceURIFunc; - - V8Proxy* proxy = V8Proxy::retrieve(); - v8::Handle<v8::Value> retval = proxy->CallFunction(function, m_resolver, argc, argv); - - // Eat exceptions from namespace resolver and return an empty string. This - // will most likely cause NAMESPACE_ERR. - if (try_catch.HasCaught()) { - return String(); - } - - return valueToStringWithNullCheck(retval); -} - -} - -#endif // ENABLE(XPATH) diff --git a/webkit/port/bindings/v8/JSXPathNSResolver.h b/webkit/port/bindings/v8/JSXPathNSResolver.h deleted file mode 100644 index f0c340c..0000000 --- a/webkit/port/bindings/v8/JSXPathNSResolver.h +++ /dev/null @@ -1,33 +0,0 @@ -// Copyright (c) 2006-2008 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#ifndef JSXPATHNSRESOLVER_H__ -#define JSXPATHNSRESOLVER_H__ - -#if ENABLE(XPATH) - -#include <v8.h> -#include <wtf/RefCounted.h> -#include "XPathNSResolver.h" - -namespace WebCore { - - class String; - - class JSXPathNSResolver : public XPathNSResolver { - public: - - JSXPathNSResolver(v8::Handle<v8::Object> resolver); - virtual ~JSXPathNSResolver(); - - virtual String lookupNamespaceURI(const String& prefix); - - private: - v8::Handle<v8::Object> m_resolver; // Handle to resolver object. - }; -} - -#endif // ENABLE(XPATH) - -#endif // JSXPATHNSRESOLVER_H__ diff --git a/webkit/webkit.gyp b/webkit/webkit.gyp index 7c54e1e..ce82a5f 100644 --- a/webkit/webkit.gyp +++ b/webkit/webkit.gyp @@ -1143,8 +1143,6 @@ 'extensions/v8/benchmarking_extension.cc', 'extensions/v8/benchmarking_extension.h', 'port/bindings/v8/DOMObjectsInclude.h', - 'port/bindings/v8/JSXPathNSResolver.cpp', - 'port/bindings/v8/JSXPathNSResolver.h', 'port/bindings/v8/RGBColor.cpp', 'port/bindings/v8/RGBColor.h', 'port/bindings/v8/V8SVGPODTypeWrapper.h', |