2015-05-03 12:32:37 -07:00
|
|
|
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
|
|
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
|
2012-05-21 04:12:37 -07:00
|
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
2009-08-27 11:05:23 -07:00
|
|
|
|
2013-01-04 09:02:13 -08:00
|
|
|
#include "mozilla/dom/HTMLAnchorElement.h"
|
2013-06-30 09:26:39 -07:00
|
|
|
|
2013-01-04 09:02:13 -08:00
|
|
|
#include "mozilla/dom/HTMLAnchorElementBinding.h"
|
2014-03-17 21:48:21 -07:00
|
|
|
#include "mozilla/EventDispatcher.h"
|
2014-04-02 21:18:36 -07:00
|
|
|
#include "mozilla/EventStates.h"
|
2013-07-10 02:56:47 -07:00
|
|
|
#include "mozilla/MemoryReporting.h"
|
2007-03-22 10:30:00 -07:00
|
|
|
#include "nsCOMPtr.h"
|
2011-08-11 06:29:50 -07:00
|
|
|
#include "nsContentUtils.h"
|
2007-03-22 10:30:00 -07:00
|
|
|
#include "nsGkAtoms.h"
|
2013-07-10 02:56:47 -07:00
|
|
|
#include "nsHTMLDNSPrefetch.h"
|
2009-08-27 11:05:23 -07:00
|
|
|
#include "nsIDocument.h"
|
2013-07-10 02:56:47 -07:00
|
|
|
#include "nsIPresShell.h"
|
2007-03-22 10:30:00 -07:00
|
|
|
#include "nsPresContext.h"
|
2013-08-23 19:42:40 -07:00
|
|
|
#include "nsIURI.h"
|
2008-11-07 15:00:26 -08:00
|
|
|
|
2013-01-04 09:02:13 -08:00
|
|
|
NS_IMPL_NS_NEW_HTML_ELEMENT(Anchor)
|
2012-06-04 16:49:57 -07:00
|
|
|
|
2013-01-04 09:02:13 -08:00
|
|
|
namespace mozilla {
|
|
|
|
namespace dom {
|
2008-02-21 12:39:20 -08:00
|
|
|
|
2012-10-01 17:52:06 -07:00
|
|
|
#define ANCHOR_ELEMENT_FLAG_BIT(n_) NODE_FLAG_BIT(ELEMENT_TYPE_SPECIFIC_BITS_OFFSET + (n_))
|
|
|
|
|
|
|
|
// Anchor element specific bits
|
|
|
|
enum {
|
|
|
|
// Indicates that a DNS Prefetch has been requested from this Anchor elem
|
|
|
|
HTML_ANCHOR_DNS_PREFETCH_REQUESTED = ANCHOR_ELEMENT_FLAG_BIT(0),
|
|
|
|
|
|
|
|
// Indicates that a DNS Prefetch was added to the deferral queue
|
|
|
|
HTML_ANCHOR_DNS_PREFETCH_DEFERRED = ANCHOR_ELEMENT_FLAG_BIT(1)
|
|
|
|
};
|
2012-01-20 15:14:46 -08:00
|
|
|
|
2013-06-08 01:54:59 -07:00
|
|
|
ASSERT_NODE_FLAGS_SPACE(ELEMENT_TYPE_SPECIFIC_BITS_OFFSET + 2);
|
2012-10-01 17:52:06 -07:00
|
|
|
|
|
|
|
#undef ANCHOR_ELEMENT_FLAG_BIT
|
2008-02-21 12:39:20 -08:00
|
|
|
|
2013-01-04 09:02:13 -08:00
|
|
|
HTMLAnchorElement::~HTMLAnchorElement()
|
2007-03-22 10:30:00 -07:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2015-05-29 02:23:08 -07:00
|
|
|
bool
|
|
|
|
HTMLAnchorElement::IsInteractiveHTMLContent(bool aIgnoreTabindex) const
|
|
|
|
{
|
|
|
|
return HasAttr(kNameSpaceID_None, nsGkAtoms::href) ||
|
|
|
|
nsGenericHTMLElement::IsInteractiveHTMLContent(aIgnoreTabindex);
|
|
|
|
}
|
|
|
|
|
2013-12-12 11:30:27 -08:00
|
|
|
NS_INTERFACE_TABLE_HEAD_CYCLE_COLLECTION_INHERITED(HTMLAnchorElement)
|
2014-04-27 00:06:00 -07:00
|
|
|
NS_INTERFACE_TABLE_INHERITED(HTMLAnchorElement,
|
|
|
|
nsIDOMHTMLAnchorElement,
|
|
|
|
Link)
|
2013-12-12 11:30:27 -08:00
|
|
|
NS_INTERFACE_TABLE_TAIL_INHERITING(nsGenericHTMLElement)
|
|
|
|
|
|
|
|
NS_IMPL_ADDREF_INHERITED(HTMLAnchorElement, Element)
|
|
|
|
NS_IMPL_RELEASE_INHERITED(HTMLAnchorElement, Element)
|
|
|
|
|
|
|
|
NS_IMPL_CYCLE_COLLECTION_CLASS(HTMLAnchorElement)
|
|
|
|
|
|
|
|
NS_IMPL_CYCLE_COLLECTION_TRAVERSE_BEGIN_INHERITED(HTMLAnchorElement,
|
|
|
|
nsGenericHTMLElement)
|
2014-10-23 08:32:35 -07:00
|
|
|
tmp->Link::Traverse(cb);
|
2014-03-11 05:04:26 -07:00
|
|
|
NS_IMPL_CYCLE_COLLECTION_TRAVERSE(mRelList)
|
2013-12-12 11:30:27 -08:00
|
|
|
NS_IMPL_CYCLE_COLLECTION_TRAVERSE_END
|
|
|
|
|
|
|
|
NS_IMPL_CYCLE_COLLECTION_UNLINK_BEGIN_INHERITED(HTMLAnchorElement,
|
|
|
|
nsGenericHTMLElement)
|
2014-10-23 08:32:35 -07:00
|
|
|
tmp->Link::Unlink();
|
2014-03-11 05:04:26 -07:00
|
|
|
NS_IMPL_CYCLE_COLLECTION_UNLINK(mRelList)
|
2013-12-12 11:30:27 -08:00
|
|
|
NS_IMPL_CYCLE_COLLECTION_UNLINK_END
|
2008-02-21 12:39:20 -08:00
|
|
|
|
2013-01-04 09:02:13 -08:00
|
|
|
NS_IMPL_ELEMENT_CLONE(HTMLAnchorElement)
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2013-01-04 09:02:13 -08:00
|
|
|
JSObject*
|
Bug 1117172 part 3. Change the wrappercached WrapObject methods to allow passing in aGivenProto. r=peterv
The only manual changes here are to BindingUtils.h, BindingUtils.cpp,
Codegen.py, Element.cpp, IDBFileRequest.cpp, IDBObjectStore.cpp,
dom/workers/Navigator.cpp, WorkerPrivate.cpp, DeviceStorageRequestChild.cpp,
Notification.cpp, nsGlobalWindow.cpp, MessagePort.cpp, nsJSEnvironment.cpp,
Sandbox.cpp, XPCConvert.cpp, ExportHelpers.cpp, and DataStoreService.cpp. The
rest of this diff was generated by running the following commands:
find . -name "*.h" -o -name "*.cpp" | xargs perl -pi -e 'BEGIN { $/ = undef } s/(WrapObjectInternal\(JSContext *\* *(?:aCx|cx|aContext|aCtx|js))\)/\1, JS::Handle<JSObject*> aGivenProto)/g'
find . -name "*.h" -o -name "*.cpp" | xargs perl -pi -e 'BEGIN { $/ = undef } s/(WrapObjectInternal\((?:aCx|cx|aContext|aCtx|js))\)/\1, aGivenProto)/g'
find . -name "*.h" -o -name "*.cpp" | xargs perl -pi -e 'BEGIN { $/ = undef } s/(WrapNode\(JSContext *\* *(?:aCx|cx|aContext|aCtx|js))\)/\1, JS::Handle<JSObject*> aGivenProto)/g'
find . -name "*.h" -o -name "*.cpp" | xargs perl -pi -e 'BEGIN { $/ = undef } s/(WrapNode\((?:aCx|cx|aContext|aCtx|js))\)/\1, aGivenProto)/g'
find . -name "*.h" -o -name "*.cpp" | xargs perl -pi -e 'BEGIN { $/ = undef } s/(WrapObject\(JSContext *\* *(?:aCx|cx|aContext|aCtx|js))\)/\1, JS::Handle<JSObject*> aGivenProto)/g'
find . -name "*.h" -o -name "*.cpp" | xargs perl -pi -e 'BEGIN { $/ = undef } s/(Binding(?:_workers)?::Wrap\((?:aCx|cx|aContext|aCtx|js), [^,)]+)\)/\1, aGivenProto)/g'
2015-03-19 07:13:33 -07:00
|
|
|
HTMLAnchorElement::WrapNode(JSContext *aCx, JS::Handle<JSObject*> aGivenProto)
|
2013-01-04 09:02:13 -08:00
|
|
|
{
|
Bug 1117172 part 3. Change the wrappercached WrapObject methods to allow passing in aGivenProto. r=peterv
The only manual changes here are to BindingUtils.h, BindingUtils.cpp,
Codegen.py, Element.cpp, IDBFileRequest.cpp, IDBObjectStore.cpp,
dom/workers/Navigator.cpp, WorkerPrivate.cpp, DeviceStorageRequestChild.cpp,
Notification.cpp, nsGlobalWindow.cpp, MessagePort.cpp, nsJSEnvironment.cpp,
Sandbox.cpp, XPCConvert.cpp, ExportHelpers.cpp, and DataStoreService.cpp. The
rest of this diff was generated by running the following commands:
find . -name "*.h" -o -name "*.cpp" | xargs perl -pi -e 'BEGIN { $/ = undef } s/(WrapObjectInternal\(JSContext *\* *(?:aCx|cx|aContext|aCtx|js))\)/\1, JS::Handle<JSObject*> aGivenProto)/g'
find . -name "*.h" -o -name "*.cpp" | xargs perl -pi -e 'BEGIN { $/ = undef } s/(WrapObjectInternal\((?:aCx|cx|aContext|aCtx|js))\)/\1, aGivenProto)/g'
find . -name "*.h" -o -name "*.cpp" | xargs perl -pi -e 'BEGIN { $/ = undef } s/(WrapNode\(JSContext *\* *(?:aCx|cx|aContext|aCtx|js))\)/\1, JS::Handle<JSObject*> aGivenProto)/g'
find . -name "*.h" -o -name "*.cpp" | xargs perl -pi -e 'BEGIN { $/ = undef } s/(WrapNode\((?:aCx|cx|aContext|aCtx|js))\)/\1, aGivenProto)/g'
find . -name "*.h" -o -name "*.cpp" | xargs perl -pi -e 'BEGIN { $/ = undef } s/(WrapObject\(JSContext *\* *(?:aCx|cx|aContext|aCtx|js))\)/\1, JS::Handle<JSObject*> aGivenProto)/g'
find . -name "*.h" -o -name "*.cpp" | xargs perl -pi -e 'BEGIN { $/ = undef } s/(Binding(?:_workers)?::Wrap\((?:aCx|cx|aContext|aCtx|js), [^,)]+)\)/\1, aGivenProto)/g'
2015-03-19 07:13:33 -07:00
|
|
|
return HTMLAnchorElementBinding::Wrap(aCx, this, aGivenProto);
|
2013-01-04 09:02:13 -08:00
|
|
|
}
|
2008-02-21 12:39:20 -08:00
|
|
|
|
2013-01-04 09:02:13 -08:00
|
|
|
NS_IMPL_STRING_ATTR(HTMLAnchorElement, Charset, charset)
|
|
|
|
NS_IMPL_STRING_ATTR(HTMLAnchorElement, Coords, coords)
|
|
|
|
NS_IMPL_URI_ATTR(HTMLAnchorElement, Href, href)
|
|
|
|
NS_IMPL_STRING_ATTR(HTMLAnchorElement, Hreflang, hreflang)
|
|
|
|
NS_IMPL_STRING_ATTR(HTMLAnchorElement, Name, name)
|
|
|
|
NS_IMPL_STRING_ATTR(HTMLAnchorElement, Rel, rel)
|
|
|
|
NS_IMPL_STRING_ATTR(HTMLAnchorElement, Rev, rev)
|
|
|
|
NS_IMPL_STRING_ATTR(HTMLAnchorElement, Shape, shape)
|
|
|
|
NS_IMPL_STRING_ATTR(HTMLAnchorElement, Type, type)
|
|
|
|
NS_IMPL_STRING_ATTR(HTMLAnchorElement, Download, download)
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2012-10-06 00:19:51 -07:00
|
|
|
int32_t
|
2013-01-04 09:02:13 -08:00
|
|
|
HTMLAnchorElement::TabIndexDefault()
|
2012-10-06 00:19:51 -07:00
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2012-06-04 16:49:57 -07:00
|
|
|
void
|
2015-02-12 17:27:39 -08:00
|
|
|
HTMLAnchorElement::GetItemValueText(DOMString& aValue)
|
2012-06-04 16:49:57 -07:00
|
|
|
{
|
|
|
|
GetHref(aValue);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2013-01-04 09:02:13 -08:00
|
|
|
HTMLAnchorElement::SetItemValueText(const nsAString& aValue)
|
2012-06-04 16:49:57 -07:00
|
|
|
{
|
|
|
|
SetHref(aValue);
|
|
|
|
}
|
|
|
|
|
2012-10-06 00:19:52 -07:00
|
|
|
bool
|
2013-01-04 09:02:13 -08:00
|
|
|
HTMLAnchorElement::Draggable() const
|
2008-08-27 05:07:27 -07:00
|
|
|
{
|
|
|
|
// links can be dragged as long as there is an href and the
|
|
|
|
// draggable attribute isn't false
|
2012-10-06 00:19:52 -07:00
|
|
|
if (!HasAttr(kNameSpaceID_None, nsGkAtoms::href)) {
|
|
|
|
// no href, so just use the same behavior as other elements
|
|
|
|
return nsGenericHTMLElement::Draggable();
|
2008-08-27 05:07:27 -07:00
|
|
|
}
|
|
|
|
|
2012-10-06 00:19:52 -07:00
|
|
|
return !AttrValueIs(kNameSpaceID_None, nsGkAtoms::draggable,
|
|
|
|
nsGkAtoms::_false, eIgnoreCase);
|
2008-08-27 05:07:27 -07:00
|
|
|
}
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2012-01-20 15:14:46 -08:00
|
|
|
void
|
2013-01-04 09:02:13 -08:00
|
|
|
HTMLAnchorElement::OnDNSPrefetchRequested()
|
2012-01-20 15:14:46 -08:00
|
|
|
{
|
|
|
|
UnsetFlags(HTML_ANCHOR_DNS_PREFETCH_DEFERRED);
|
|
|
|
SetFlags(HTML_ANCHOR_DNS_PREFETCH_REQUESTED);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2013-01-04 09:02:13 -08:00
|
|
|
HTMLAnchorElement::OnDNSPrefetchDeferred()
|
2012-01-20 15:14:46 -08:00
|
|
|
{
|
|
|
|
UnsetFlags(HTML_ANCHOR_DNS_PREFETCH_REQUESTED);
|
|
|
|
SetFlags(HTML_ANCHOR_DNS_PREFETCH_DEFERRED);
|
|
|
|
}
|
|
|
|
|
|
|
|
bool
|
2013-01-04 09:02:13 -08:00
|
|
|
HTMLAnchorElement::HasDeferredDNSPrefetchRequest()
|
2012-01-20 15:14:46 -08:00
|
|
|
{
|
|
|
|
return HasFlag(HTML_ANCHOR_DNS_PREFETCH_DEFERRED);
|
|
|
|
}
|
|
|
|
|
2007-03-22 10:30:00 -07:00
|
|
|
nsresult
|
2013-01-04 09:02:13 -08:00
|
|
|
HTMLAnchorElement::BindToTree(nsIDocument* aDocument, nsIContent* aParent,
|
|
|
|
nsIContent* aBindingParent,
|
|
|
|
bool aCompileEventHandlers)
|
2007-03-22 10:30:00 -07:00
|
|
|
{
|
2012-12-07 06:35:14 -08:00
|
|
|
Link::ResetLinkState(false, Link::ElementHasHref());
|
2009-11-23 10:48:52 -08:00
|
|
|
|
2007-03-22 10:30:00 -07:00
|
|
|
nsresult rv = nsGenericHTMLElement::BindToTree(aDocument, aParent,
|
|
|
|
aBindingParent,
|
|
|
|
aCompileEventHandlers);
|
|
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
|
|
|
2008-12-05 12:53:24 -08:00
|
|
|
// Prefetch links
|
2014-10-02 12:07:24 -07:00
|
|
|
nsIDocument* doc = GetComposedDoc();
|
|
|
|
if (doc) {
|
|
|
|
doc->RegisterPendingLinkUpdate(this);
|
2011-11-13 19:24:41 -08:00
|
|
|
if (nsHTMLDNSPrefetch::IsAllowed(OwnerDoc())) {
|
|
|
|
nsHTMLDNSPrefetch::PrefetchLow(this);
|
|
|
|
}
|
2008-12-05 12:53:24 -08:00
|
|
|
}
|
2011-11-13 19:24:41 -08:00
|
|
|
|
2007-03-22 10:30:00 -07:00
|
|
|
return rv;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2013-01-04 09:02:13 -08:00
|
|
|
HTMLAnchorElement::UnbindFromTree(bool aDeep, bool aNullParent)
|
2007-03-22 10:30:00 -07:00
|
|
|
{
|
2012-01-20 15:14:46 -08:00
|
|
|
// Cancel any DNS prefetches
|
|
|
|
// Note: Must come before ResetLinkState. If called after, it will recreate
|
|
|
|
// mCachedURI based on data that is invalid - due to a call to GetHostname.
|
|
|
|
|
|
|
|
// If prefetch was deferred, clear flag and move on
|
|
|
|
if (HasFlag(HTML_ANCHOR_DNS_PREFETCH_DEFERRED))
|
|
|
|
UnsetFlags(HTML_ANCHOR_DNS_PREFETCH_DEFERRED);
|
|
|
|
// Else if prefetch was requested, clear flag and send cancellation
|
|
|
|
else if (HasFlag(HTML_ANCHOR_DNS_PREFETCH_REQUESTED)) {
|
|
|
|
UnsetFlags(HTML_ANCHOR_DNS_PREFETCH_REQUESTED);
|
|
|
|
// Possible that hostname could have changed since binding, but since this
|
|
|
|
// covers common cases, most DNS prefetch requests will be canceled
|
|
|
|
nsHTMLDNSPrefetch::CancelPrefetchLow(this, NS_ERROR_ABORT);
|
|
|
|
}
|
|
|
|
|
2009-11-23 10:48:52 -08:00
|
|
|
// If this link is ever reinserted into a document, it might
|
|
|
|
// be under a different xml:base, so forget the cached state now.
|
2012-12-07 06:35:14 -08:00
|
|
|
Link::ResetLinkState(false, Link::ElementHasHref());
|
2014-10-02 12:07:24 -07:00
|
|
|
|
|
|
|
// Note, we need to use OwnerDoc() here, since GetComposedDoc() might
|
|
|
|
// return null.
|
|
|
|
nsIDocument* doc = OwnerDoc();
|
2011-11-13 19:24:41 -08:00
|
|
|
if (doc) {
|
|
|
|
doc->UnregisterPendingLinkUpdate(this);
|
|
|
|
}
|
2009-11-23 10:48:52 -08:00
|
|
|
|
2007-03-22 10:30:00 -07:00
|
|
|
nsGenericHTMLElement::UnbindFromTree(aDeep, aNullParent);
|
|
|
|
}
|
|
|
|
|
2015-01-17 15:50:09 -08:00
|
|
|
static bool
|
|
|
|
IsNodeInEditableRegion(nsINode* aNode)
|
|
|
|
{
|
|
|
|
while (aNode) {
|
|
|
|
if (aNode->IsEditable()) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
aNode = aNode->GetParent();
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2011-09-28 23:19:26 -07:00
|
|
|
bool
|
2013-01-04 09:02:13 -08:00
|
|
|
HTMLAnchorElement::IsHTMLFocusable(bool aWithMouse,
|
|
|
|
bool *aIsFocusable, int32_t *aTabIndex)
|
2007-03-22 10:30:00 -07:00
|
|
|
{
|
2010-06-21 05:37:34 -07:00
|
|
|
if (nsGenericHTMLElement::IsHTMLFocusable(aWithMouse, aIsFocusable, aTabIndex)) {
|
2011-10-17 07:59:28 -07:00
|
|
|
return true;
|
2008-04-15 11:40:38 -07:00
|
|
|
}
|
|
|
|
|
Bug 178324, refactor focus by moving all focus handling into one place and simplifying it, add many tests, fixes many other bugs too numerous to mention in this small checkin comment, r=josh,smichaud,ere,dbaron,marco,neil,gavin,smaug,sr=smaug (CLOSED TREE)
2009-06-10 11:00:39 -07:00
|
|
|
// cannot focus links if there is no link handler
|
2014-08-22 13:11:27 -07:00
|
|
|
nsIDocument* doc = GetComposedDoc();
|
Bug 178324, refactor focus by moving all focus handling into one place and simplifying it, add many tests, fixes many other bugs too numerous to mention in this small checkin comment, r=josh,smichaud,ere,dbaron,marco,neil,gavin,smaug,sr=smaug (CLOSED TREE)
2009-06-10 11:00:39 -07:00
|
|
|
if (doc) {
|
2010-06-25 06:59:57 -07:00
|
|
|
nsIPresShell* presShell = doc->GetShell();
|
Bug 178324, refactor focus by moving all focus handling into one place and simplifying it, add many tests, fixes many other bugs too numerous to mention in this small checkin comment, r=josh,smichaud,ere,dbaron,marco,neil,gavin,smaug,sr=smaug (CLOSED TREE)
2009-06-10 11:00:39 -07:00
|
|
|
if (presShell) {
|
|
|
|
nsPresContext* presContext = presShell->GetPresContext();
|
|
|
|
if (presContext && !presContext->GetLinkHandler()) {
|
2011-10-17 07:59:28 -07:00
|
|
|
*aIsFocusable = false;
|
|
|
|
return false;
|
Bug 178324, refactor focus by moving all focus handling into one place and simplifying it, add many tests, fixes many other bugs too numerous to mention in this small checkin comment, r=josh,smichaud,ere,dbaron,marco,neil,gavin,smaug,sr=smaug (CLOSED TREE)
2009-06-10 11:00:39 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-01-17 15:50:09 -08:00
|
|
|
// Links that are in an editable region should never be focusable, even if
|
|
|
|
// they are in a contenteditable="false" region.
|
|
|
|
if (IsNodeInEditableRegion(this)) {
|
2008-04-15 11:40:38 -07:00
|
|
|
if (aTabIndex) {
|
|
|
|
*aTabIndex = -1;
|
|
|
|
}
|
|
|
|
|
2011-10-17 07:59:28 -07:00
|
|
|
*aIsFocusable = false;
|
2008-04-15 11:40:38 -07:00
|
|
|
|
2011-10-17 07:59:28 -07:00
|
|
|
return true;
|
2007-03-22 10:30:00 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
if (!HasAttr(kNameSpaceID_None, nsGkAtoms::tabindex)) {
|
|
|
|
// check whether we're actually a link
|
2012-05-22 20:03:32 -07:00
|
|
|
if (!Link::HasURI()) {
|
2007-03-22 10:30:00 -07:00
|
|
|
// Not tabbable or focusable without href (bug 17605), unless
|
|
|
|
// forced to be via presence of nonnegative tabindex attribute
|
|
|
|
if (aTabIndex) {
|
|
|
|
*aTabIndex = -1;
|
|
|
|
}
|
2008-04-15 11:40:38 -07:00
|
|
|
|
2011-10-17 07:59:28 -07:00
|
|
|
*aIsFocusable = false;
|
2008-04-15 11:40:38 -07:00
|
|
|
|
2011-10-17 07:59:28 -07:00
|
|
|
return false;
|
2007-03-22 10:30:00 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (aTabIndex && (sTabFocusModel & eTabFocus_linksMask) == 0) {
|
|
|
|
*aTabIndex = -1;
|
|
|
|
}
|
|
|
|
|
2011-10-17 07:59:28 -07:00
|
|
|
*aIsFocusable = true;
|
2008-04-15 11:40:38 -07:00
|
|
|
|
2011-10-17 07:59:28 -07:00
|
|
|
return false;
|
2007-03-22 10:30:00 -07:00
|
|
|
}
|
|
|
|
|
2007-04-23 00:31:21 -07:00
|
|
|
nsresult
|
2014-03-17 21:48:19 -07:00
|
|
|
HTMLAnchorElement::PreHandleEvent(EventChainPreVisitor& aVisitor)
|
2007-04-23 00:31:21 -07:00
|
|
|
{
|
|
|
|
return PreHandleEventForAnchors(aVisitor);
|
|
|
|
}
|
|
|
|
|
2007-03-22 10:30:00 -07:00
|
|
|
nsresult
|
2014-03-17 21:48:20 -07:00
|
|
|
HTMLAnchorElement::PostHandleEvent(EventChainPostVisitor& aVisitor)
|
2007-03-22 10:30:00 -07:00
|
|
|
{
|
|
|
|
return PostHandleEventForAnchors(aVisitor);
|
|
|
|
}
|
|
|
|
|
2011-09-28 23:19:26 -07:00
|
|
|
bool
|
2013-01-04 09:02:13 -08:00
|
|
|
HTMLAnchorElement::IsLink(nsIURI** aURI) const
|
2007-03-22 10:30:00 -07:00
|
|
|
{
|
|
|
|
return IsHTMLLink(aURI);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2013-01-04 09:02:13 -08:00
|
|
|
HTMLAnchorElement::GetLinkTarget(nsAString& aTarget)
|
2007-03-22 10:30:00 -07:00
|
|
|
{
|
2007-03-26 06:19:33 -07:00
|
|
|
GetAttr(kNameSpaceID_None, nsGkAtoms::target, aTarget);
|
|
|
|
if (aTarget.IsEmpty()) {
|
|
|
|
GetBaseTarget(aTarget);
|
|
|
|
}
|
2007-03-22 10:30:00 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
NS_IMETHODIMP
|
2013-01-04 09:02:13 -08:00
|
|
|
HTMLAnchorElement::GetTarget(nsAString& aValue)
|
2007-03-22 10:30:00 -07:00
|
|
|
{
|
|
|
|
if (!GetAttr(kNameSpaceID_None, nsGkAtoms::target, aValue)) {
|
|
|
|
GetBaseTarget(aValue);
|
|
|
|
}
|
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
NS_IMETHODIMP
|
2013-01-04 09:02:13 -08:00
|
|
|
HTMLAnchorElement::SetTarget(const nsAString& aValue)
|
2007-03-22 10:30:00 -07:00
|
|
|
{
|
2011-10-17 07:59:28 -07:00
|
|
|
return SetAttr(kNameSpaceID_None, nsGkAtoms::target, aValue, true);
|
2007-03-22 10:30:00 -07:00
|
|
|
}
|
|
|
|
|
2014-03-11 05:04:26 -07:00
|
|
|
nsDOMTokenList*
|
|
|
|
HTMLAnchorElement::RelList()
|
|
|
|
{
|
|
|
|
if (!mRelList) {
|
|
|
|
mRelList = new nsDOMTokenList(this, nsGkAtoms::rel);
|
|
|
|
}
|
|
|
|
return mRelList;
|
|
|
|
}
|
|
|
|
|
2009-03-09 19:32:09 -07:00
|
|
|
#define IMPL_URI_PART(_part) \
|
|
|
|
NS_IMETHODIMP \
|
2013-01-04 09:02:13 -08:00
|
|
|
HTMLAnchorElement::Get##_part(nsAString& a##_part) \
|
2009-03-09 19:32:09 -07:00
|
|
|
{ \
|
2014-07-11 16:30:27 -07:00
|
|
|
ErrorResult rv; \
|
|
|
|
Link::Get##_part(a##_part, rv); \
|
|
|
|
MOZ_ASSERT(!rv.Failed()); \
|
2013-01-04 09:02:13 -08:00
|
|
|
return NS_OK; \
|
2009-03-09 19:32:09 -07:00
|
|
|
} \
|
|
|
|
NS_IMETHODIMP \
|
2013-01-04 09:02:13 -08:00
|
|
|
HTMLAnchorElement::Set##_part(const nsAString& a##_part) \
|
2009-03-09 19:32:09 -07:00
|
|
|
{ \
|
2014-07-11 16:30:27 -07:00
|
|
|
ErrorResult rv; \
|
|
|
|
Link::Set##_part(a##_part, rv); \
|
|
|
|
MOZ_ASSERT(!rv.Failed()); \
|
2013-01-04 09:02:13 -08:00
|
|
|
return NS_OK; \
|
2009-03-09 19:32:09 -07:00
|
|
|
}
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2009-03-09 19:32:09 -07:00
|
|
|
IMPL_URI_PART(Protocol)
|
|
|
|
IMPL_URI_PART(Host)
|
|
|
|
IMPL_URI_PART(Hostname)
|
|
|
|
IMPL_URI_PART(Pathname)
|
|
|
|
IMPL_URI_PART(Search)
|
|
|
|
IMPL_URI_PART(Port)
|
|
|
|
IMPL_URI_PART(Hash)
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2009-03-09 19:32:09 -07:00
|
|
|
#undef IMPL_URI_PART
|
2007-03-22 10:30:00 -07:00
|
|
|
|
|
|
|
NS_IMETHODIMP
|
2013-01-04 09:02:13 -08:00
|
|
|
HTMLAnchorElement::GetText(nsAString& aText)
|
2007-03-22 10:30:00 -07:00
|
|
|
{
|
2015-05-22 11:16:20 -07:00
|
|
|
if(!nsContentUtils::GetNodeTextContent(this, true, aText, fallible)) {
|
2014-03-20 12:51:16 -07:00
|
|
|
return NS_ERROR_OUT_OF_MEMORY;
|
|
|
|
}
|
2007-03-22 10:30:00 -07:00
|
|
|
return NS_OK;
|
|
|
|
}
|
|
|
|
|
2010-07-30 16:48:57 -07:00
|
|
|
NS_IMETHODIMP
|
2013-01-04 09:02:13 -08:00
|
|
|
HTMLAnchorElement::SetText(const nsAString& aText)
|
2010-07-30 16:48:57 -07:00
|
|
|
{
|
2011-10-17 07:59:28 -07:00
|
|
|
return nsContentUtils::SetNodeTextContent(this, aText, false);
|
2010-07-30 16:48:57 -07:00
|
|
|
}
|
|
|
|
|
2007-03-22 10:30:00 -07:00
|
|
|
NS_IMETHODIMP
|
2013-01-04 09:02:13 -08:00
|
|
|
HTMLAnchorElement::ToString(nsAString& aSource)
|
2007-03-22 10:30:00 -07:00
|
|
|
{
|
|
|
|
return GetHref(aSource);
|
|
|
|
}
|
|
|
|
|
|
|
|
NS_IMETHODIMP
|
2013-01-04 09:02:13 -08:00
|
|
|
HTMLAnchorElement::GetPing(nsAString& aValue)
|
2007-03-22 10:30:00 -07:00
|
|
|
{
|
|
|
|
return GetURIListAttr(nsGkAtoms::ping, aValue);
|
|
|
|
}
|
|
|
|
|
|
|
|
NS_IMETHODIMP
|
2013-01-04 09:02:13 -08:00
|
|
|
HTMLAnchorElement::SetPing(const nsAString& aValue)
|
2007-03-22 10:30:00 -07:00
|
|
|
{
|
2011-10-17 07:59:28 -07:00
|
|
|
return SetAttr(kNameSpaceID_None, nsGkAtoms::ping, aValue, true);
|
2007-03-22 10:30:00 -07:00
|
|
|
}
|
|
|
|
|
2009-07-13 04:48:06 -07:00
|
|
|
already_AddRefed<nsIURI>
|
2013-01-04 09:02:13 -08:00
|
|
|
HTMLAnchorElement::GetHrefURI() const
|
2007-03-22 10:30:00 -07:00
|
|
|
{
|
2013-04-22 04:15:59 -07:00
|
|
|
nsCOMPtr<nsIURI> uri = Link::GetCachedURI();
|
2012-05-23 23:57:16 -07:00
|
|
|
if (uri) {
|
2013-04-22 04:15:59 -07:00
|
|
|
return uri.forget();
|
2012-05-23 23:57:16 -07:00
|
|
|
}
|
|
|
|
|
2009-07-13 04:48:06 -07:00
|
|
|
return GetHrefURIForAnchors();
|
2007-03-22 10:30:00 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
nsresult
|
2013-01-04 09:02:13 -08:00
|
|
|
HTMLAnchorElement::SetAttr(int32_t aNameSpaceID, nsIAtom* aName,
|
|
|
|
nsIAtom* aPrefix, const nsAString& aValue,
|
|
|
|
bool aNotify)
|
2007-03-22 10:30:00 -07:00
|
|
|
{
|
2010-02-24 08:37:38 -08:00
|
|
|
bool reset = false;
|
2007-03-22 10:30:00 -07:00
|
|
|
if (aName == nsGkAtoms::href && kNameSpaceID_None == aNameSpaceID) {
|
2010-06-16 09:59:26 -07:00
|
|
|
// If we do not have a cached URI, we have some value here so we must reset
|
|
|
|
// our link state after calling the parent.
|
|
|
|
if (!Link::HasCachedURI()) {
|
2010-02-24 08:37:38 -08:00
|
|
|
reset = true;
|
2007-03-22 10:30:00 -07:00
|
|
|
}
|
2010-06-16 09:59:26 -07:00
|
|
|
// However, if we have a cached URI, we'll want to see if the value changed.
|
|
|
|
else {
|
|
|
|
nsAutoString val;
|
|
|
|
GetHref(val);
|
|
|
|
if (!val.Equals(aValue)) {
|
|
|
|
reset = true;
|
|
|
|
}
|
|
|
|
}
|
2007-03-22 10:30:00 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
nsresult rv = nsGenericHTMLElement::SetAttr(aNameSpaceID, aName, aPrefix,
|
|
|
|
aValue, aNotify);
|
|
|
|
|
2010-02-24 08:37:38 -08:00
|
|
|
// The ordering of the parent class's SetAttr call and Link::ResetLinkState
|
|
|
|
// is important here! The attribute is not set until SetAttr returns, and
|
|
|
|
// we will need the updated attribute value because notifying the document
|
|
|
|
// that content states have changed will call IntrinsicState, which will try
|
|
|
|
// to get updated information about the visitedness from Link.
|
|
|
|
if (reset) {
|
2012-12-07 06:35:14 -08:00
|
|
|
Link::ResetLinkState(!!aNotify, true);
|
2010-02-24 08:37:38 -08:00
|
|
|
}
|
|
|
|
|
2007-03-22 10:30:00 -07:00
|
|
|
return rv;
|
|
|
|
}
|
|
|
|
|
|
|
|
nsresult
|
2013-01-04 09:02:13 -08:00
|
|
|
HTMLAnchorElement::UnsetAttr(int32_t aNameSpaceID, nsIAtom* aAttribute,
|
|
|
|
bool aNotify)
|
2007-03-22 10:30:00 -07:00
|
|
|
{
|
2010-03-03 12:55:35 -08:00
|
|
|
nsresult rv = nsGenericHTMLElement::UnsetAttr(aNameSpaceID, aAttribute,
|
|
|
|
aNotify);
|
|
|
|
|
|
|
|
// The ordering of the parent class's UnsetAttr call and Link::ResetLinkState
|
|
|
|
// is important here! The attribute is not unset until UnsetAttr returns, and
|
|
|
|
// we will need the updated attribute value because notifying the document
|
|
|
|
// that content states have changed will call IntrinsicState, which will try
|
|
|
|
// to get updated information about the visitedness from Link.
|
|
|
|
if (aAttribute == nsGkAtoms::href && kNameSpaceID_None == aNameSpaceID) {
|
2012-12-07 06:35:14 -08:00
|
|
|
Link::ResetLinkState(!!aNotify, false);
|
2010-03-03 12:55:35 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
return rv;
|
2007-03-22 10:30:00 -07:00
|
|
|
}
|
2009-03-10 06:51:34 -07:00
|
|
|
|
2011-09-28 23:19:26 -07:00
|
|
|
bool
|
2013-01-04 09:02:13 -08:00
|
|
|
HTMLAnchorElement::ParseAttribute(int32_t aNamespaceID,
|
|
|
|
nsIAtom* aAttribute,
|
|
|
|
const nsAString& aValue,
|
|
|
|
nsAttrValue& aResult)
|
2009-03-10 06:51:34 -07:00
|
|
|
{
|
|
|
|
return nsGenericHTMLElement::ParseAttribute(aNamespaceID, aAttribute, aValue,
|
|
|
|
aResult);
|
|
|
|
}
|
|
|
|
|
2014-04-02 21:18:36 -07:00
|
|
|
EventStates
|
2013-01-04 09:02:13 -08:00
|
|
|
HTMLAnchorElement::IntrinsicState() const
|
2009-12-15 16:04:09 -08:00
|
|
|
{
|
|
|
|
return Link::LinkState() | nsGenericHTMLElement::IntrinsicState();
|
|
|
|
}
|
2011-08-17 15:14:53 -07:00
|
|
|
|
2012-02-19 19:51:48 -08:00
|
|
|
size_t
|
2013-06-23 05:03:39 -07:00
|
|
|
HTMLAnchorElement::SizeOfExcludingThis(mozilla::MallocSizeOf aMallocSizeOf) const
|
2012-02-19 19:51:48 -08:00
|
|
|
{
|
|
|
|
return nsGenericHTMLElement::SizeOfExcludingThis(aMallocSizeOf) +
|
|
|
|
Link::SizeOfExcludingThis(aMallocSizeOf);
|
|
|
|
}
|
|
|
|
|
2013-01-04 09:02:13 -08:00
|
|
|
} // namespace dom
|
2015-07-13 08:25:42 -07:00
|
|
|
} // namespace mozilla
|