зеркало из https://github.com/mozilla/gecko-dev.git
Bug 1432186 part 9. Remove nsIDOMNode::CloneNode. r=mccr8
MozReview-Commit-ID: 3x3wJ9H38Wx
This commit is contained in:
Родитель
df23390565
Коммит
baca310fed
|
@ -10116,12 +10116,15 @@ nsIDocument::CreateStaticClone(nsIDocShell* aCloneContainer)
|
||||||
// Make document use different container during cloning.
|
// Make document use different container during cloning.
|
||||||
RefPtr<nsDocShell> originalShell = mDocumentContainer.get();
|
RefPtr<nsDocShell> originalShell = mDocumentContainer.get();
|
||||||
SetContainer(static_cast<nsDocShell*>(aCloneContainer));
|
SetContainer(static_cast<nsDocShell*>(aCloneContainer));
|
||||||
nsCOMPtr<nsIDOMNode> clonedNode;
|
ErrorResult rv;
|
||||||
nsresult rv = thisAsDoc->CloneNode(true, 1, getter_AddRefs(clonedNode));
|
nsCOMPtr<nsINode> clonedNode = thisAsDoc->CloneNode(true, rv);
|
||||||
SetContainer(originalShell);
|
SetContainer(originalShell);
|
||||||
|
|
||||||
RefPtr<nsDocument> clonedDoc;
|
RefPtr<nsDocument> clonedDoc;
|
||||||
if (NS_SUCCEEDED(rv)) {
|
if (rv.Failed()) {
|
||||||
|
// Don't return yet; we need to reset mCreatingStaticClone
|
||||||
|
rv.SuppressException();
|
||||||
|
} else {
|
||||||
nsCOMPtr<nsIDocument> tmp = do_QueryInterface(clonedNode);
|
nsCOMPtr<nsIDocument> tmp = do_QueryInterface(clonedNode);
|
||||||
if (tmp) {
|
if (tmp) {
|
||||||
clonedDoc = static_cast<nsDocument*>(tmp.get());
|
clonedDoc = static_cast<nsDocument*>(tmp.get());
|
||||||
|
|
|
@ -2301,19 +2301,6 @@ ToCanonicalSupports(nsINode* aPointer)
|
||||||
{ \
|
{ \
|
||||||
*aResult = nsINode::HasChildNodes(); \
|
*aResult = nsINode::HasChildNodes(); \
|
||||||
return NS_OK; \
|
return NS_OK; \
|
||||||
} \
|
|
||||||
NS_IMETHOD CloneNode(bool aDeep, uint8_t aArgc, nsIDOMNode** aResult) __VA_ARGS__ override \
|
|
||||||
{ \
|
|
||||||
if (aArgc == 0) { \
|
|
||||||
aDeep = true; \
|
|
||||||
} \
|
|
||||||
mozilla::ErrorResult rv; \
|
|
||||||
nsCOMPtr<nsINode> clone = nsINode::CloneNode(aDeep, rv); \
|
|
||||||
if (rv.Failed()) { \
|
|
||||||
return rv.StealNSResult(); \
|
|
||||||
} \
|
|
||||||
*aResult = clone.forget().take()->AsDOMNode(); \
|
|
||||||
return NS_OK; \
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#define NS_FORWARD_NSIDOMNODE_TO_NSINODE \
|
#define NS_FORWARD_NSIDOMNODE_TO_NSINODE \
|
||||||
|
|
|
@ -41,6 +41,4 @@ interface nsIDOMNode : nsISupports
|
||||||
// Modified in DOM Level 2:
|
// Modified in DOM Level 2:
|
||||||
readonly attribute nsIDOMDocument ownerDocument;
|
readonly attribute nsIDOMDocument ownerDocument;
|
||||||
boolean hasChildNodes();
|
boolean hasChildNodes();
|
||||||
// Modified in DOM Level 4:
|
|
||||||
[optional_argc] nsIDOMNode cloneNode([optional] in boolean deep);
|
|
||||||
};
|
};
|
||||||
|
|
Загрузка…
Ссылка в новой задаче