2015-05-03 22:32:37 +03: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: */
|
2013-05-02 02:50:08 +04: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/. */
|
|
|
|
|
2013-07-02 02:09:37 +04:00
|
|
|
#include "mozilla/dom/XBLChildrenElement.h"
|
2013-05-02 02:50:08 +04:00
|
|
|
#include "nsCharSeparatedTokenizer.h"
|
|
|
|
#include "mozilla/dom/NodeListBinding.h"
|
2017-06-07 20:28:20 +03:00
|
|
|
#include "nsAttrValueOrString.h"
|
2013-05-02 02:50:08 +04:00
|
|
|
|
2013-07-02 02:09:37 +04:00
|
|
|
namespace mozilla {
|
|
|
|
namespace dom {
|
|
|
|
|
|
|
|
XBLChildrenElement::~XBLChildrenElement() {}
|
2013-05-02 02:50:08 +04:00
|
|
|
|
2013-07-02 02:09:37 +04:00
|
|
|
NS_IMPL_ELEMENT_CLONE(XBLChildrenElement)
|
2013-05-02 02:50:08 +04:00
|
|
|
|
2017-10-03 01:05:19 +03:00
|
|
|
nsresult XBLChildrenElement::BeforeSetAttr(int32_t aNamespaceID, nsAtom* aName,
|
2017-06-07 20:28:20 +03:00
|
|
|
const nsAttrValueOrString* aValue,
|
|
|
|
bool aNotify) {
|
|
|
|
if (aNamespaceID == kNameSpaceID_None) {
|
|
|
|
if (aName == nsGkAtoms::includes) {
|
|
|
|
mIncludes.Clear();
|
|
|
|
if (aValue) {
|
|
|
|
nsCharSeparatedTokenizer tok(
|
|
|
|
aValue->String(), '|',
|
|
|
|
nsCharSeparatedTokenizer::SEPARATOR_OPTIONAL);
|
|
|
|
while (tok.hasMoreTokens()) {
|
|
|
|
mIncludes.AppendElement(NS_Atomize(tok.nextToken()));
|
|
|
|
}
|
|
|
|
}
|
2013-05-02 02:50:08 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-06-07 20:28:20 +03:00
|
|
|
return nsXMLElement::BeforeSetAttr(aNamespaceID, aName, aValue, aNotify);
|
2013-05-02 02:50:08 +04:00
|
|
|
}
|
|
|
|
|
2018-04-14 16:04:53 +03:00
|
|
|
void XBLChildrenElement::DoRemoveDefaultContent(bool aNotify) {
|
|
|
|
// Default content is going away, need to tell layout about it first.
|
|
|
|
MOZ_ASSERT(HasChildren(), "Why bothering?");
|
|
|
|
MOZ_ASSERT(GetParentElement());
|
|
|
|
|
|
|
|
// We don't want to do this from frame construction while setting up the
|
|
|
|
// binding initially.
|
|
|
|
if (aNotify) {
|
|
|
|
Element* parent = GetParentElement();
|
|
|
|
if (nsIDocument* doc = parent->GetComposedDoc()) {
|
|
|
|
if (nsIPresShell* shell = doc->GetShell()) {
|
|
|
|
shell->DestroyFramesForAndRestyle(parent);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for (nsIContent* child = static_cast<nsINode*>(this)->GetFirstChild(); child;
|
|
|
|
child = child->GetNextSibling()) {
|
|
|
|
MOZ_ASSERT(!child->GetPrimaryFrame());
|
|
|
|
MOZ_ASSERT(!child->IsElement() || !child->AsElement()->HasServoData());
|
|
|
|
child->SetXBLInsertionPoint(nullptr);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-07-02 02:09:37 +04:00
|
|
|
} // namespace dom
|
2015-07-13 18:25:42 +03:00
|
|
|
} // namespace mozilla
|
2013-07-02 02:09:37 +04:00
|
|
|
|
|
|
|
using namespace mozilla::dom;
|
|
|
|
|
2014-04-29 12:57:00 +04:00
|
|
|
NS_IMPL_CYCLE_COLLECTION_WRAPPERCACHE(nsAnonymousContentList, mParent)
|
2013-05-02 02:50:08 +04:00
|
|
|
|
|
|
|
NS_IMPL_CYCLE_COLLECTING_ADDREF(nsAnonymousContentList)
|
|
|
|
NS_IMPL_CYCLE_COLLECTING_RELEASE(nsAnonymousContentList)
|
|
|
|
|
|
|
|
NS_INTERFACE_TABLE_HEAD(nsAnonymousContentList)
|
2014-08-26 03:21:35 +04:00
|
|
|
NS_WRAPPERCACHE_INTERFACE_TABLE_ENTRY
|
2018-04-26 00:01:30 +03:00
|
|
|
NS_INTERFACE_TABLE(nsAnonymousContentList, nsINodeList)
|
2017-08-16 23:37:20 +03:00
|
|
|
NS_INTERFACE_TABLE_TO_MAP_SEGUE_CYCLE_COLLECTION(nsAnonymousContentList)
|
2013-05-02 02:50:08 +04:00
|
|
|
NS_INTERFACE_MAP_END
|
|
|
|
|
2018-03-20 21:02:08 +03:00
|
|
|
uint32_t nsAnonymousContentList::Length() {
|
2013-05-02 02:50:08 +04:00
|
|
|
if (!mParent) {
|
2018-03-20 21:02:08 +03:00
|
|
|
return 0;
|
2013-05-02 02:50:08 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
uint32_t count = 0;
|
|
|
|
for (nsIContent* child = mParent->GetFirstChild(); child;
|
|
|
|
child = child->GetNextSibling()) {
|
|
|
|
if (child->NodeInfo()->Equals(nsGkAtoms::children, kNameSpaceID_XBL)) {
|
2013-07-02 02:09:37 +04:00
|
|
|
XBLChildrenElement* point = static_cast<XBLChildrenElement*>(child);
|
2014-06-22 15:53:01 +04:00
|
|
|
if (point->HasInsertedChildren()) {
|
|
|
|
count += point->InsertedChildrenLength();
|
2013-05-02 02:50:08 +04:00
|
|
|
} else {
|
|
|
|
count += point->GetChildCount();
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
++count;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-03-20 21:02:08 +03:00
|
|
|
return count;
|
2013-05-02 02:50:08 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
nsIContent* nsAnonymousContentList::Item(uint32_t aIndex) {
|
|
|
|
if (!mParent) {
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
uint32_t remIndex = aIndex;
|
|
|
|
for (nsIContent* child = mParent->GetFirstChild(); child;
|
|
|
|
child = child->GetNextSibling()) {
|
|
|
|
if (child->NodeInfo()->Equals(nsGkAtoms::children, kNameSpaceID_XBL)) {
|
2013-07-02 02:09:37 +04:00
|
|
|
XBLChildrenElement* point = static_cast<XBLChildrenElement*>(child);
|
2014-06-22 15:53:01 +04:00
|
|
|
if (point->HasInsertedChildren()) {
|
|
|
|
if (remIndex < point->InsertedChildrenLength()) {
|
|
|
|
return point->InsertedChild(remIndex);
|
2013-05-02 02:50:08 +04:00
|
|
|
}
|
2014-06-22 15:53:01 +04:00
|
|
|
remIndex -= point->InsertedChildrenLength();
|
2013-05-02 02:50:08 +04:00
|
|
|
} else {
|
|
|
|
if (remIndex < point->GetChildCount()) {
|
2018-01-03 15:59:54 +03:00
|
|
|
return point->GetChildAt_Deprecated(remIndex);
|
2013-05-02 02:50:08 +04:00
|
|
|
}
|
|
|
|
remIndex -= point->GetChildCount();
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if (remIndex == 0) {
|
|
|
|
return child;
|
|
|
|
}
|
|
|
|
--remIndex;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
int32_t nsAnonymousContentList::IndexOf(nsIContent* aContent) {
|
|
|
|
NS_ASSERTION(
|
|
|
|
!aContent->NodeInfo()->Equals(nsGkAtoms::children, kNameSpaceID_XBL),
|
|
|
|
"Looking for insertion point");
|
|
|
|
|
|
|
|
if (!mParent) {
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
2014-06-22 15:53:01 +04:00
|
|
|
int32_t index = 0;
|
2013-05-02 02:50:08 +04:00
|
|
|
for (nsIContent* child = mParent->GetFirstChild(); child;
|
|
|
|
child = child->GetNextSibling()) {
|
|
|
|
if (child->NodeInfo()->Equals(nsGkAtoms::children, kNameSpaceID_XBL)) {
|
2013-07-02 02:09:37 +04:00
|
|
|
XBLChildrenElement* point = static_cast<XBLChildrenElement*>(child);
|
2014-06-22 15:53:01 +04:00
|
|
|
if (point->HasInsertedChildren()) {
|
|
|
|
int32_t insIndex = point->IndexOfInsertedChild(aContent);
|
|
|
|
if (insIndex != -1) {
|
2013-05-02 02:50:08 +04:00
|
|
|
return index + insIndex;
|
|
|
|
}
|
2014-06-22 15:53:01 +04:00
|
|
|
index += point->InsertedChildrenLength();
|
2013-05-02 02:50:08 +04:00
|
|
|
} else {
|
2018-01-23 16:30:18 +03:00
|
|
|
int32_t insIndex = point->ComputeIndexOf(aContent);
|
2013-05-02 02:50:08 +04:00
|
|
|
if (insIndex != -1) {
|
2014-06-22 15:53:01 +04:00
|
|
|
return index + insIndex;
|
2013-05-02 02:50:08 +04:00
|
|
|
}
|
|
|
|
index += point->GetChildCount();
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if (child == aContent) {
|
|
|
|
return index;
|
|
|
|
}
|
|
|
|
++index;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
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 17:13:33 +03:00
|
|
|
JSObject* nsAnonymousContentList::WrapObject(
|
|
|
|
JSContext* cx, JS::Handle<JSObject*> aGivenProto) {
|
2018-06-26 00:20:54 +03:00
|
|
|
return mozilla::dom::NodeList_Binding::Wrap(cx, this, aGivenProto);
|
2013-05-02 02:50:08 +04:00
|
|
|
}
|