Source code

Revision control

Copy as Markdown

Other Tools

/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* 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/. */
#include "XULAlertAccessible.h"
#include "LocalAccessible-inl.h"
#include "mozilla/a11y/Role.h"
#include "States.h"
using namespace mozilla::a11y;
////////////////////////////////////////////////////////////////////////////////
// XULAlertAccessible
////////////////////////////////////////////////////////////////////////////////
XULAlertAccessible::XULAlertAccessible(nsIContent* aContent,
DocAccessible* aDoc)
: AccessibleWrap(aContent, aDoc) {
mGenericTypes |= eAlert;
}
XULAlertAccessible::~XULAlertAccessible() {}
role XULAlertAccessible::NativeRole() const { return roles::ALERT; }
uint64_t XULAlertAccessible::NativeState() const {
return LocalAccessible::NativeState() | states::ALERT;
}
ENameValueFlag XULAlertAccessible::Name(nsString& aName) const {
// Screen readers need to read contents of alert, not the accessible name.
// If we have both some screen readers will read the alert twice.
aName.Truncate();
return eNameOK;
}
////////////////////////////////////////////////////////////////////////////////
// Widgets
bool XULAlertAccessible::IsWidget() const { return true; }
LocalAccessible* XULAlertAccessible::ContainerWidget() const { return nullptr; }