/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ /* vim: set ts=8 sts=2 et sw=2 tw=80: */ /* 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/. */
/* * nsIContentSerializer implementation that can be used with an * nsIDocumentEncoder to convert an HTML (not XHTML!) DOM to an HTML * string that could be parsed into more or less the original DOM.
*/
int32_t count = aElement->GetAttrCount(); if (!count) returntrue;
nsresult rv;
nsAutoString valueStr;
for (int32_t index = 0; index < count; index++) { const nsAttrName* name = aElement->GetAttrNameAt(index);
int32_t namespaceID = name->NamespaceID();
nsAtom* attrName = name->LocalName();
// Filter out any attribute starting with [-|_]moz
nsDependentAtomString attrNameStr(attrName); if (StringBeginsWith(attrNameStr, u"_moz"_ns) ||
StringBeginsWith(attrNameStr, u"-moz"_ns)) { continue;
}
aElement->GetAttr(namespaceID, attrName, valueStr);
if (mIsCopying && mIsFirstChildOfOL && aTagName == nsGkAtoms::li &&
aNamespace == kNameSpaceID_XHTML && attrName == nsGkAtoms::value &&
namespaceID == kNameSpaceID_None) { // This is handled separately in SerializeLIValueAttribute() continue;
} bool isJS = IsJavaScript(aElement, attrName, namespaceID, valueStr);
if (((attrName == nsGkAtoms::href && (namespaceID == kNameSpaceID_None ||
namespaceID == kNameSpaceID_XLink)) ||
(attrName == nsGkAtoms::src && namespaceID == kNameSpaceID_None))) { // Make all links absolute when converting only the selection: if (mFlags & nsIDocumentEncoder::OutputAbsoluteLinks) { // Would be nice to handle OBJECT tags, but that gets more complicated // since we have to search the tag list for CODEBASE as well. For now, // just leave them relative.
nsIURI* uri = aElement->GetBaseURI(); if (uri) {
nsAutoString absURI;
rv = NS_MakeAbsoluteURI(absURI, valueStr, uri); if (NS_SUCCEEDED(rv)) {
valueStr = absURI;
}
}
}
}
if (mRewriteEncodingDeclaration && aTagName == nsGkAtoms::meta &&
aNamespace == kNameSpaceID_XHTML && attrName == nsGkAtoms::content &&
namespaceID == kNameSpaceID_None) { // If we're serializing a <meta http-equiv="content-type">, // use the proper value, rather than what's in the document.
nsAutoString header;
aElement->GetAttr(nsGkAtoms::httpEquiv, header); if (header.LowerCaseEqualsLiteral("content-type")) {
valueStr = u"text/html; charset="_ns + NS_ConvertASCIItoUTF16(mCharset);
}
}
bool forceFormat = false;
nsresult rv = NS_OK; if (!CheckElementStart(aElement, forceFormat, *mOutput, rv)) { // When we go to AppendElementEnd for this element, we're going to // MaybeLeaveFromPreContent(). So make sure to MaybeEnterInPreContent() // now, so our PreLevel() doesn't get confused.
MaybeEnterInPreContent(aElement); return rv;
}
NS_ENSURE_SUCCESS(rv, rv);
nsAtom* name = aElement->NodeInfo()->NameAtom();
int32_t ns = aElement->GetNameSpaceID();
// for block elements, we increase the indentation if ((mDoFormat || forceFormat) && !mDoRaw && !PreLevel())
NS_ENSURE_TRUE(IncrIndentation(name), NS_ERROR_OUT_OF_MEMORY);
// Need to keep track of OL and LI elements in order to get ordinal number // for the LI. if (mIsCopying && name == nsGkAtoms::ol && ns == kNameSpaceID_XHTML) { // We are copying and current node is an OL; // Store its start attribute value in olState->startVal.
nsAutoString start;
int32_t startAttrVal = 0;
aElement->GetAttr(nsGkAtoms::start, start); if (!start.IsEmpty()) {
nsresult rv = NS_OK;
startAttrVal = start.ToInteger(&rv); // If OL has "start" attribute, first LI element has to start with that // value Therefore subtracting 1 as all the LI elements are incrementing // it before using it; In failure of ToInteger(), default StartAttrValue // to 0. if (NS_SUCCEEDED(rv))
startAttrVal--; else
startAttrVal = 0;
}
mOLStateStack.AppendElement(olState(startAttrVal, true));
}
if (mIsCopying && name == nsGkAtoms::li && ns == kNameSpaceID_XHTML) {
mIsFirstChildOfOL = IsFirstChildOfOL(aOriginalElement); if (mIsFirstChildOfOL) { // If OL is parent of this LI, serialize attributes in different manner.
NS_ENSURE_TRUE(SerializeLIValueAttribute(aElement, *mOutput),
NS_ERROR_OUT_OF_MEMORY);
}
}
// Even LI passed above have to go through this // for serializing attributes other than "value".
nsAutoString dummyPrefix;
NS_ENSURE_TRUE(
SerializeHTMLAttributes(aElement, aOriginalElement, dummyPrefix, u""_ns,
name, ns, *mOutput),
NS_ERROR_OUT_OF_MEMORY);
if (name == nsGkAtoms::script) {
nsCOMPtr<nsIScriptElement> script = do_QueryInterface(aElement);
if (ShouldMaintainPreLevel() && script && script->IsMalformed()) { // We're looking at a malformed script tag. This means that the end tag // was missing in the source. Imitate that here by not serializing the end // tag.
--PreLevel(); return NS_OK;
}
} elseif (mIsCopying && name == nsGkAtoms::ol && ns == kNameSpaceID_XHTML) {
NS_ASSERTION((!mOLStateStack.IsEmpty()), "Cannot have an empty OL Stack"); /* Though at this point we must always have an state to be deleted as all
the OL opening tags are supposed to push an olState object to the stack*/ if (!mOLStateStack.IsEmpty()) {
mOLStateStack.RemoveLastElement();
}
}
if (ns == kNameSpaceID_XHTML) { bool isContainer =
nsHTMLElement::IsContainer(nsHTMLTags::CaseSensitiveAtomTagToId(name)); if (!isContainer) { // Keep this in sync with the cleanup at the end of this method.
MOZ_ASSERT(name != nsGkAtoms::body);
MaybeLeaveFromPreContent(aElement); return NS_OK;
}
}
if (mDisableEntityEncoding) { return aOutputStr.Append(aStr, mozilla::fallible);
}
if (mFlags & (nsIDocumentEncoder::OutputEncodeBasicEntities)) { // Per the API documentation, encode , &, <, >, and " if (mInAttribute) { return nsXMLContentSerializer::AppendAndTranslateEntities<kValNBSP>(
aStr, aOutputStr, kAttrEntities, kEntityStrings);
}
// We don't want to call into our superclass 2-arg version of // AppendAndTranslateEntities, because it wants to encode more characters // than we do. Use our tables, but avoid encoding by passing in a // smaller max index. This will only encode &, <, >, and ". if (mInAttribute) { return nsXMLContentSerializer::AppendAndTranslateEntities<kGTVal>(
aStr, aOutputStr, kAttrEntities, kEntityStrings);
}
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung ist noch experimentell.