2006-03-14 20:12:41 +03:00
|
|
|
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
2012-05-21 15:12:37 +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/. */
|
2006-03-14 20:12:41 +03:00
|
|
|
|
|
|
|
#include "nsISupports.idl"
|
|
|
|
|
2006-05-01 09:25:52 +04:00
|
|
|
interface nsIDOMDocument;
|
2006-03-14 20:12:41 +03:00
|
|
|
interface nsIDOMRange;
|
|
|
|
interface nsISelection;
|
|
|
|
interface nsIDOMNode;
|
|
|
|
interface nsIOutputStream;
|
|
|
|
|
2010-06-27 00:39:56 +04:00
|
|
|
%{ C++
|
|
|
|
class nsINode;
|
|
|
|
class nsIDocument;
|
|
|
|
%}
|
|
|
|
[ptr] native nsINodePtr(nsINode);
|
|
|
|
[ptr] native nsIDocumentPtr(nsIDocument);
|
|
|
|
|
2013-07-11 19:48:43 +04:00
|
|
|
[scriptable, uuid(3d9371d8-a2ad-403e-8b0e-8885ad3562e3)]
|
2006-03-14 20:12:41 +03:00
|
|
|
interface nsIDocumentEncoderNodeFixup : nsISupports
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Create a fixed up version of a node. This method is called before
|
|
|
|
* each node in a document is about to be persisted. The implementor
|
|
|
|
* may return a new node with fixed up attributes or null. If null is
|
|
|
|
* returned the node should be used as-is.
|
|
|
|
* @param aNode Node to fixup.
|
2008-07-29 09:59:25 +04:00
|
|
|
* @param [OUT] aSerializeCloneKids True if the document encoder should
|
|
|
|
* apply recursive serialization to the children of the fixed up node
|
|
|
|
* instead of the children of the original node.
|
2006-03-14 20:12:41 +03:00
|
|
|
* @return The resulting fixed up node.
|
|
|
|
*/
|
2008-07-29 09:59:25 +04:00
|
|
|
nsIDOMNode fixupNode(in nsIDOMNode aNode, out boolean aSerializeCloneKids);
|
2006-03-14 20:12:41 +03:00
|
|
|
};
|
|
|
|
|
2015-11-27 17:27:00 +03:00
|
|
|
[scriptable, uuid(21f112df-d96f-47da-bfcb-5331273003d1)]
|
2006-03-14 20:12:41 +03:00
|
|
|
interface nsIDocumentEncoder : nsISupports
|
|
|
|
{
|
|
|
|
// Output methods flag bits. There are a frightening number of these,
|
|
|
|
// because everyone wants something a little bit different
|
|
|
|
|
2017-08-04 12:37:53 +03:00
|
|
|
|
|
|
|
/**
|
2006-03-14 20:12:41 +03:00
|
|
|
* Output only the selection (as opposed to the whole document).
|
|
|
|
*/
|
|
|
|
const unsigned long OutputSelectionOnly = (1 << 0);
|
|
|
|
|
|
|
|
/** Plaintext output: Convert html to plaintext that looks like the html.
|
|
|
|
* Implies wrap (except inside <pre>), since html wraps.
|
2009-04-25 13:00:14 +04:00
|
|
|
* HTML, XHTML and XML output: do prettyprinting, ignoring existing formatting.
|
|
|
|
* XML output : it doesn't implicitly wrap
|
2006-03-14 20:12:41 +03:00
|
|
|
*/
|
|
|
|
const unsigned long OutputFormatted = (1 << 1);
|
|
|
|
|
2009-04-25 13:00:14 +04:00
|
|
|
/** Don't do prettyprinting. Don't do any wrapping that's not in the existing
|
|
|
|
* HTML/XML source. This option overrides OutputFormatted if both are set.
|
|
|
|
* HTML/XHTML output: If neither are set, there won't be prettyprinting too, but
|
|
|
|
* long lines will be wrapped.
|
|
|
|
* Supported also in XML and Plaintext output.
|
2006-03-14 20:12:41 +03:00
|
|
|
* @note This option does not affect entity conversion.
|
|
|
|
*/
|
|
|
|
const unsigned long OutputRaw = (1 << 2);
|
|
|
|
|
2017-08-04 12:37:53 +03:00
|
|
|
/**
|
2006-03-14 20:12:41 +03:00
|
|
|
* Do not print html head tags.
|
2009-04-25 13:00:14 +04:00
|
|
|
* XHTML/HTML output only.
|
2006-03-14 20:12:41 +03:00
|
|
|
*/
|
|
|
|
const unsigned long OutputBodyOnly = (1 << 3);
|
|
|
|
|
|
|
|
/**
|
2009-04-25 13:00:14 +04:00
|
|
|
* Output as though the content is preformatted
|
|
|
|
* (e.g. maybe it's wrapped in a PRE or PRE_WRAP style tag)
|
2008-10-22 00:30:09 +04:00
|
|
|
* Plaintext output only.
|
|
|
|
* XXXbz How does this interact with
|
2009-04-25 13:00:14 +04:00
|
|
|
* OutputFormatted/OutputRaw/OutputPreformatted/OutputFormatFlowed?
|
2006-03-14 20:12:41 +03:00
|
|
|
*/
|
|
|
|
const unsigned long OutputPreformatted = (1 << 4);
|
|
|
|
|
|
|
|
/**
|
2009-04-25 13:00:14 +04:00
|
|
|
* Wrap even if we're not doing formatted output (e.g. for text fields).
|
|
|
|
* Supported in XML, XHTML, HTML and Plaintext output.
|
|
|
|
* Set implicitly in HTML/XHTML output when no OutputRaw.
|
|
|
|
* Ignored when OutputRaw.
|
|
|
|
* XXXLJ: set implicitly in HTML/XHTML output, to keep compatible behaviors
|
|
|
|
* for old callers of this interface
|
|
|
|
* XXXbz How does this interact with OutputFormatFlowed?
|
2006-03-14 20:12:41 +03:00
|
|
|
*/
|
|
|
|
const unsigned long OutputWrap = (1 << 5);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Output for format flowed (RFC 2646). This is used when converting
|
|
|
|
* to text for mail sending. This differs just slightly
|
|
|
|
* but in an important way from normal formatted, and that is that
|
|
|
|
* lines are space stuffed. This can't (correctly) be done later.
|
2008-10-22 00:30:09 +04:00
|
|
|
* PlainText output only.
|
|
|
|
* XXXbz How does this interact with
|
2006-03-14 20:12:41 +03:00
|
|
|
* OutputFormatted/OutputRaw/OutputPreformatted/OutputWrap?
|
|
|
|
*/
|
|
|
|
const unsigned long OutputFormatFlowed = (1 << 6);
|
|
|
|
|
|
|
|
/**
|
2008-10-22 00:30:09 +04:00
|
|
|
* Convert links, image src, and script src to absolute URLs when possible.
|
2009-04-25 13:00:14 +04:00
|
|
|
* XHTML/HTML output only.
|
2006-03-14 20:12:41 +03:00
|
|
|
*/
|
|
|
|
const unsigned long OutputAbsoluteLinks = (1 << 7);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* LineBreak processing: if this flag is set than CR line breaks will
|
|
|
|
* be written. If neither this nor OutputLFLineBreak is set, then we
|
|
|
|
* will use platform line breaks. The combination of the two flags will
|
|
|
|
* cause CRLF line breaks to be written.
|
|
|
|
*/
|
|
|
|
const unsigned long OutputCRLineBreak = (1 << 9);
|
|
|
|
|
2017-08-04 12:37:53 +03:00
|
|
|
/**
|
2006-03-14 20:12:41 +03:00
|
|
|
* LineBreak processing: if this flag is set than LF line breaks will
|
|
|
|
* be written. If neither this nor OutputCRLineBreak is set, then we
|
|
|
|
* will use platform line breaks. The combination of the two flags will
|
|
|
|
* cause CRLF line breaks to be written.
|
|
|
|
*/
|
|
|
|
const unsigned long OutputLFLineBreak = (1 << 10);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Output the content of noscript elements (only for serializing
|
|
|
|
* to plaintext).
|
|
|
|
*/
|
|
|
|
const unsigned long OutputNoScriptContent = (1 << 11);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Output the content of noframes elements (only for serializing
|
2012-02-27 15:57:48 +04:00
|
|
|
* to plaintext). (Used only internally in the plain text serializer;
|
|
|
|
* ignored if passed by the caller.)
|
2006-03-14 20:12:41 +03:00
|
|
|
*/
|
|
|
|
const unsigned long OutputNoFramesContent = (1 << 12);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Don't allow any formatting nodes (e.g. <br>, <b>) inside a <pre>.
|
2009-04-25 13:00:14 +04:00
|
|
|
* This is used primarily by mail. XHTML/HTML output only.
|
2006-03-14 20:12:41 +03:00
|
|
|
*/
|
|
|
|
const unsigned long OutputNoFormattingInPre = (1 << 13);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Encode entities when outputting to a string.
|
|
|
|
* E.g. If set, we'll output if clear, we'll output 0xa0.
|
|
|
|
* The basic set is just & < > " for interoperability
|
|
|
|
* with older products that don't support α and friends.
|
2010-03-18 19:07:32 +03:00
|
|
|
* HTML output only.
|
2006-03-14 20:12:41 +03:00
|
|
|
*/
|
|
|
|
const unsigned long OutputEncodeBasicEntities = (1 << 14);
|
|
|
|
|
2006-08-07 07:27:49 +04:00
|
|
|
/**
|
2006-08-07 09:05:11 +04:00
|
|
|
* Normally is replaced with a space character when
|
2006-08-07 07:27:49 +04:00
|
|
|
* encoding data as plain text, set this flag if that's
|
|
|
|
* not desired.
|
2008-10-22 00:30:09 +04:00
|
|
|
* Plaintext output only.
|
2006-08-07 07:27:49 +04:00
|
|
|
*/
|
|
|
|
const unsigned long OutputPersistNBSP = (1 << 17);
|
2009-09-28 11:59:52 +04:00
|
|
|
|
|
|
|
/**
|
2017-08-04 12:37:53 +03:00
|
|
|
* Normally when serializing the whole document using the HTML or
|
2009-09-28 11:59:52 +04:00
|
|
|
* XHTML serializer, the encoding declaration is rewritten to match.
|
|
|
|
* This flag suppresses that behavior.
|
|
|
|
*/
|
|
|
|
const unsigned long OutputDontRewriteEncodingDeclaration = (1 << 18);
|
2017-08-04 12:37:53 +03:00
|
|
|
|
2010-05-31 11:07:35 +04:00
|
|
|
/**
|
2010-05-31 11:01:07 +04:00
|
|
|
* When using the HTML or XHTML serializer, skip elements that are not
|
|
|
|
* visible when this flag is set. Elements are not visible when they
|
|
|
|
* have CSS style display:none or visibility:collapse, for example.
|
|
|
|
*/
|
|
|
|
const unsigned long SkipInvisibleContent = (1 << 19);
|
2017-08-04 12:37:53 +03:00
|
|
|
|
2010-04-02 13:21:40 +04:00
|
|
|
/**
|
|
|
|
* Output for delsp=yes (RFC 3676). This is used with OutputFormatFlowed
|
|
|
|
* when converting to text for mail sending.
|
|
|
|
* PlainText output only.
|
|
|
|
*/
|
2010-05-31 11:01:07 +04:00
|
|
|
const unsigned long OutputFormatDelSp = (1 << 20);
|
2017-08-04 12:37:53 +03:00
|
|
|
|
2012-03-31 18:10:34 +04:00
|
|
|
/**
|
|
|
|
* Drop <br> elements considered "invisible" by the editor. OutputPreformatted
|
|
|
|
* implies this flag.
|
|
|
|
*/
|
|
|
|
const unsigned long OutputDropInvisibleBreak = (1 << 21);
|
|
|
|
|
2012-04-24 10:06:11 +04:00
|
|
|
/**
|
|
|
|
* Don't check for _moz_dirty attributes when deciding whether to
|
|
|
|
* pretty-print if this flag is set (bug 599983).
|
|
|
|
*/
|
|
|
|
const unsigned long OutputIgnoreMozDirty = (1 << 22);
|
|
|
|
|
2013-07-11 19:48:43 +04:00
|
|
|
/**
|
|
|
|
* Output the content of non-text elements as the placehodler character
|
|
|
|
* U+FFFC (OBJECT REPLACEMENT CHARACTER, only for serializing to plaintext).
|
|
|
|
*/
|
|
|
|
const unsigned long OutputNonTextContentAsPlaceholder = (1 << 23);
|
|
|
|
|
2013-09-06 00:10:04 +04:00
|
|
|
/**
|
|
|
|
* Don't Strip ending spaces from a line (only for serializing to plaintext).
|
|
|
|
*/
|
|
|
|
const unsigned long OutputDontRemoveLineEndingSpaces = (1 << 24);
|
|
|
|
|
2015-01-18 01:31:59 +03:00
|
|
|
/**
|
|
|
|
* Serialize in a way that is suitable for copying a plaintext version of the
|
|
|
|
* document to the clipboard. This can for example cause line endings to be
|
|
|
|
* injected at preformatted block element boundaries.
|
|
|
|
*/
|
|
|
|
const unsigned long OutputForPlainTextClipboardCopy = (1 << 25);
|
|
|
|
|
2015-03-10 09:11:55 +03:00
|
|
|
/**
|
|
|
|
* Include ruby annotations and ruby parentheses in the output.
|
|
|
|
* PlainText output only.
|
|
|
|
*/
|
|
|
|
const unsigned long OutputRubyAnnotation = (1 << 26);
|
|
|
|
|
2015-11-27 17:27:00 +03:00
|
|
|
/**
|
|
|
|
* Disallow breaking of long character strings. This is important
|
|
|
|
* for serializing e-mail which contains CJK strings. These must
|
|
|
|
* not be broken just as "normal" longs strings aren't broken.
|
|
|
|
*/
|
|
|
|
const unsigned long OutputDisallowLineBreaking = (1 << 27);
|
|
|
|
|
2017-04-17 13:49:52 +03:00
|
|
|
/**
|
|
|
|
* Release reference of nsIDocument after using encodeTo* method to recycle
|
|
|
|
* this encoder without holding nsIDocument. To use this encoder again,
|
|
|
|
* we have to call init again.
|
|
|
|
*/
|
|
|
|
const unsigned long RequiresReinitAfterOutput = (1 << 28);
|
|
|
|
|
2006-03-14 20:12:41 +03:00
|
|
|
/**
|
|
|
|
* Initialize with a pointer to the document and the mime type.
|
|
|
|
* @param aDocument Document to encode.
|
|
|
|
* @param aMimeType MimeType to use. May also be set by SetMimeType.
|
|
|
|
* @param aFlags Flags to use while encoding. May also be set by SetFlags.
|
|
|
|
*/
|
2006-05-01 09:25:52 +04:00
|
|
|
void init(in nsIDOMDocument aDocument,
|
|
|
|
in AString aMimeType,
|
|
|
|
in unsigned long aFlags);
|
2010-06-27 00:39:56 +04:00
|
|
|
[noscript] void nativeInit(in nsIDocumentPtr aDocument,
|
|
|
|
in AString aMimeType,
|
|
|
|
in unsigned long aFlags);
|
2006-03-14 20:12:41 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* If the selection is set to a non-null value, then the
|
|
|
|
* selection is used for encoding, otherwise the entire
|
|
|
|
* document is encoded.
|
|
|
|
* @param aSelection The selection to encode.
|
|
|
|
*/
|
|
|
|
void setSelection(in nsISelection aSelection);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* If the range is set to a non-null value, then the
|
|
|
|
* range is used for encoding, otherwise the entire
|
|
|
|
* document or selection is encoded.
|
|
|
|
* @param aRange The range to encode.
|
|
|
|
*/
|
|
|
|
void setRange(in nsIDOMRange aRange);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* If the node is set to a non-null value, then the
|
|
|
|
* node is used for encoding, otherwise the entire
|
|
|
|
* document or range or selection is encoded.
|
|
|
|
* @param aNode The node to encode.
|
|
|
|
*/
|
|
|
|
void setNode(in nsIDOMNode aNode);
|
2011-11-10 16:02:22 +04:00
|
|
|
[noscript] void setNativeNode(in nsINodePtr aNode);
|
2006-03-14 20:12:41 +03:00
|
|
|
|
2006-06-06 00:32:48 +04:00
|
|
|
/**
|
|
|
|
* If the container is set to a non-null value, then its
|
|
|
|
* child nodes are used for encoding, otherwise the entire
|
|
|
|
* document or range or selection or node is encoded.
|
|
|
|
* @param aContainer The node which child nodes will be encoded.
|
|
|
|
*/
|
|
|
|
void setContainerNode(in nsIDOMNode aContainer);
|
2010-06-27 00:39:56 +04:00
|
|
|
[noscript] void setNativeContainerNode(in nsINodePtr aContainer);
|
2006-06-06 00:32:48 +04:00
|
|
|
|
2006-03-14 20:12:41 +03:00
|
|
|
/**
|
|
|
|
* Documents typically have an intrinsic character set,
|
|
|
|
* but if no intrinsic value is found, the platform character set
|
|
|
|
* is used. This function overrides both the intrinisc and platform
|
|
|
|
* charset.
|
|
|
|
* @param aCharset Overrides the both the intrinsic or platform
|
|
|
|
* character set when encoding the document.
|
|
|
|
*
|
|
|
|
* Possible result codes: NS_ERROR_NO_CHARSET_CONVERTER
|
|
|
|
*/
|
|
|
|
void setCharset(in ACString aCharset);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set a wrap column. This may have no effect in some types of encoders.
|
|
|
|
* @param aWrapColumn Column to which to wrap.
|
|
|
|
*/
|
|
|
|
void setWrapColumn(in unsigned long aWrapColumn);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The mime type preferred by the encoder. This piece of api was
|
|
|
|
* added because the copy encoder may need to switch mime types on you
|
|
|
|
* if you ask it to copy html that really represents plaintext content.
|
|
|
|
* Call this AFTER Init() and SetSelection() have both been called.
|
|
|
|
*/
|
|
|
|
readonly attribute AString mimeType;
|
2017-08-04 12:37:53 +03:00
|
|
|
|
2006-03-14 20:12:41 +03:00
|
|
|
/**
|
|
|
|
* Encode the document and send the result to the nsIOutputStream.
|
|
|
|
*
|
|
|
|
* Possible result codes are the stream errors which might have
|
|
|
|
* been encountered.
|
|
|
|
* @param aStream Stream into which to encode.
|
|
|
|
*/
|
|
|
|
void encodeToStream(in nsIOutputStream aStream);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Encode the document into a string.
|
|
|
|
*
|
|
|
|
* @return The document encoded into a string.
|
|
|
|
*/
|
|
|
|
AString encodeToString();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Encode the document into a string. Stores the extra context information
|
|
|
|
* into the two arguments.
|
2010-04-29 23:01:11 +04:00
|
|
|
* @param [OUT] aContextString The string where the parent hierarchy
|
2006-03-14 20:12:41 +03:00
|
|
|
* information will be stored.
|
|
|
|
* @param [OUT] aInfoString The string where extra context info will
|
|
|
|
* be stored.
|
|
|
|
* @return The document encoded as a string.
|
2017-08-04 12:37:53 +03:00
|
|
|
*
|
2006-03-14 20:12:41 +03:00
|
|
|
*/
|
|
|
|
AString encodeToStringWithContext( out AString aContextString,
|
|
|
|
out AString aInfoString);
|
|
|
|
|
2014-04-17 02:01:55 +04:00
|
|
|
/**
|
|
|
|
* Encode the document into a string of limited size.
|
|
|
|
* @param aMaxLength After aMaxLength characters, the encoder will stop
|
|
|
|
* encoding new data.
|
|
|
|
* Only values > 0 will be considered.
|
|
|
|
* The returned string may be slightly larger than
|
|
|
|
* aMaxLength because some serializers (eg. HTML)
|
|
|
|
* may need to close some tags after they stop
|
|
|
|
* encoding new data, or finish a line (72 columns
|
|
|
|
* by default for the plain text serializer).
|
|
|
|
*
|
|
|
|
* @return The document encoded into a string.
|
|
|
|
*/
|
|
|
|
AString encodeToStringWithMaxLength(in unsigned long aMaxLength);
|
|
|
|
|
2006-03-14 20:12:41 +03:00
|
|
|
/**
|
|
|
|
* Set the fixup object associated with node persistence.
|
|
|
|
* @param aFixup The fixup object.
|
|
|
|
*/
|
|
|
|
void setNodeFixup(in nsIDocumentEncoderNodeFixup aFixup);
|
|
|
|
};
|