/// <reference types="node" /> import * as stream from "stream"; import * as events from "events"; // Markup data //----------------------------------------------------------------------------------- declare namespace MarkupData { interface Location { /** * One-based line index */ line: number; /** * One-based column index */ col: number; /** * Zero-based first character index */ startOffset: number; /** * Zero-based last character index */ endOffset: number; } interface AttributesLocation { [attributeName: string]: Location; } interface StartTagLocation extends Location { /** * Start tag attributes' location info */ attrs: AttributesLocation } interface ElementLocation extends StartTagLocation { /** * Element's start tag location info. */ startTag: StartTagLocation; /** * Element's end tag location info. */ endTag: Location; } } // Options //----------------------------------------------------------------------------------- declare namespace Options { export interface ParserOptions { /** * Enables source code location information. When enabled, each node (except the root node) will have a `__location` property. * If the node is not an empty element, `__location` will be a {@link MarkupData.ElementLocation} object, otherwise it will be {@link MarkupData.Location}. * If the element was implicitly created by the parser (as part of [tree correction](https://html.spec.whatwg.org/multipage/syntax.html#an-introduction-to-error-handling-and-strange-cases-in-the-parser)), its `__location` property will be `undefined`. * * **Default:** `false` */ locationInfo?: boolean; /** * Specifies the resulting tree format. * * **Default:** `treeAdapters.default` */ treeAdapter?: AST.TreeAdapter; } export interface SAXParserOptions { /** * Enables source code location information for the tokens. * When enabled, each token event handler will receive {@link MarkupData.Location} (or {@link MarkupData.StartTagLocation}) * object as its last argument. */ locationInfo?: boolean; } export interface SerializerOptions { /*** * Specifies input tree format. * * **Default:** `treeAdapters.default` */ treeAdapter?: AST.TreeAdapter; } } // AST //----------------------------------------------------------------------------------- declare namespace AST { /** * [Document mode](https://dom.spec.whatwg.org/#concept-document-limited-quirks). */ type DocumentMode = 'no-quirks' | 'quirks' | 'limited-quirks'; // Default tree adapter namespace Default { /** * Element attribute. */ interface Attribute { /** * The name of the attribute. */ name: string; /** * The value of the attribute. */ value: string; /** * The namespace of the attribute. */ namespace?: string; /** * The namespace-related prefix of the attribute. */ prefix?: string; } /** * [Default tree adapter]{@link parse5.treeAdapters} Node interface. */ interface Node { /** * The name of the node. E.g. {@link Document} will have `nodeName` equal to '#document'`. */ nodeName: string; } /** * [Default tree adapter]{@link parse5.treeAdapters} ParentNode interface. */ interface ParentNode { /** * Child nodes. */ childNodes: Node[]; } /** * [Default tree adapter]{@link parse5.treeAdapters} DocumentType interface. */ export interface DocumentType extends Node { /** * The name of the node. */ nodeName: '#documentType'; /** * Document type name. */ name: string; /** * Document type public identifier. */ publicId: string; /** * Document type system identifier. */ systemId: string; } /** * [Default tree adapter]{@link parse5.treeAdapters} Document interface. */ export interface Document extends ParentNode { /** * The name of the node. */ nodeName: '#document'; /** * [Document mode](https://dom.spec.whatwg.org/#concept-document-limited-quirks). */ mode: DocumentMode; } /** * [Default tree adapter]{@link parse5.treeAdapters} DocumentFragment interface. */ export interface DocumentFragment extends ParentNode { /** * The name of the node. */ nodeName: '#document-fragment'; } /** * [Default tree adapter]{@link parse5.treeAdapters} Element interface. */ export interface Element extends ParentNode { /** * The name of the node. Equals to element {@link tagName}. */ nodeName: string; /** * Element tag name. */ tagName: string; /** * Element namespace. */ namespaceURI: string; /** * List of element attributes. */ attrs: Attribute[]; /** * Parent node. */ parentNode: ParentNode; /** * Element source code location info. Available if location info is enabled via {@link Options.ParserOptions}. */ __location?: MarkupData.ElementLocation; } /** * [Default tree adapter]{@link parse5.treeAdapters} CommentNode interface. */ export interface CommentNode extends Node { /** * The name of the node. */ nodeName: '#comment'; /** * Comment text. */ data: string; /** * Parent node. */ parentNode: ParentNode; /** * Comment source code location info. Available if location info is enabled via {@link Options.ParserOptions}. */ __location?: MarkupData.Location; } /** * [Default tree adapter]{@link parse5.treeAdapters} TextNode interface. */ export interface TextNode extends Node { /** * The name of the node. */ nodeName: '#text'; /** * Text content. */ value: string; /** * Parent node. */ parentNode: ParentNode; /** * Text node source code location info. Available if location info is enabled via {@link Options.ParserOptions}. */ __location?: MarkupData.Location; } } // htmlparser2 tree adapter namespace HtmlParser2 { /** * [htmlparser2 tree adapter]{@link parse5.treeAdapters} Node interface. */ interface Node { /** * The type of the node. E.g. {@link Document} will have `type` equal to 'root'`. */ type: string; /** * [DOM spec](https://dom.spec.whatwg.org/#dom-node-nodetype)-compatible node {@link type}. */ nodeType: number; /** * Parent node. */ parent: ParentNode; /** * Same as {@link parent}. [DOM spec](https://dom.spec.whatwg.org)-compatible alias. */ parentNode: ParentNode; /** * Previous sibling. */ prev: Node; /** * Same as {@link prev}. [DOM spec](https://dom.spec.whatwg.org)-compatible alias. */ previousSibling: Node; /** * Next sibling. */ next: Node; /** * Same as {@link next}. [DOM spec](https://dom.spec.whatwg.org)-compatible alias. */ nextSibling: Node; } /** * [htmlparser2 tree adapter]{@link parse5.treeAdapters} ParentNode interface. */ interface ParentNode extends Node { /** * Child nodes. */ children: Node[]; /** * Same as {@link children}. [DOM spec](https://dom.spec.whatwg.org)-compatible alias. */ childNodes: Node[]; /** * First child of the node. */ firstChild: Node; /** * Last child of the node. */ lastChild: Node; } /** * [htmlparser2 tree adapter]{@link parse5.treeAdapters} DocumentType interface. */ export interface DocumentType extends Node { /** * The type of the node. */ type: 'directive'; /** * Node name. */ name: '!doctype'; /** * Serialized doctype {@link name}, {@link publicId} and {@link systemId}. */ data: string; /** * Document type name. */ 'x-name':string; /** * Document type public identifier. */ 'x-publicId': string; /** * Document type system identifier. */ 'x-systemId': string; } /** * [htmlparser2 tree adapter]{@link parse5.treeAdapters} Document interface. */ export interface Document extends ParentNode { /** * The type of the node. */ type: 'root'; /** * The name of the node. */ name: 'root'; /** * [Document mode](https://dom.spec.whatwg.org/#concept-document-limited-quirks). */ 'x-mode': DocumentMode; } /** * [htmlparser2 tree adapter]{@link parse5.treeAdapters} DocumentFragment interface. */ export interface DocumentFragment extends ParentNode { /** * The type of the node. */ type: 'root'; /** * The name of the node. */ name: 'root'; } /** * [htmlparser2 tree adapter]{@link parse5.treeAdapters} Element interface. */ export interface Element extends ParentNode { /** * The name of the node. Equals to element {@link tagName}. */ name: string; /** * Element tag name. */ tagName: string; /** * Element namespace. */ namespace: string; /** * Element attributes. */ attribs: { [name: string]: string }; /** * Element attribute namespaces. */ 'x-attribsNamespace': { [name: string]: string }; /** * Element attribute namespace-related prefixes. */ 'x-attribsPrefix': { [name: string]: string }; /** * Element source code location info. Available if location info is enabled via {@link Options.ParserOptions}. */ __location?: MarkupData.ElementLocation; } /** * [htmlparser2 tree adapter]{@link parse5.treeAdapters} CommentNode interface. */ export interface CommentNode extends Node { /** * The name of the node. */ name: 'comment'; /** * Comment text. */ data: string; /** * Same as {@link data}. [DOM spec](https://dom.spec.whatwg.org)-compatible alias. */ nodeValue: string; /** * Comment source code location info. Available if location info is enabled via {@link Options.ParserOptions}. */ __location?: MarkupData.Location; } /** * [htmlparser2 tree adapter]{@link parse5.treeAdapters} TextNode interface. */ export interface TextNode extends Node { /** * The name of the node. */ name: 'text'; /** * Text content. */ data: string; /** * Same as {@link data}. [DOM spec](https://dom.spec.whatwg.org)-compatible alias. */ nodeValue: string; /** * Comment source code location info. Available if location info is enabled via {@link Options.ParserOptions}. */ __location?: MarkupData.Location; } } // Unions // NOTE: we use `Object` in unions to support custom tree adapter implementations. // TypeScript Handbook suggests to always use `any` instead of `Object`, but in that // case language service hints `any` as type, instead of actual union name. /** * Generic Node interface. * Cast to the actual AST interface (e.g. {@link parse5.AST.Default.Node}) to get access to the properties. */ type Node = Default.Node | HtmlParser2.Node | Object; /** * Generic ParentNode interface. * Cast to the actual AST interface (e.g. {@link parse5.AST.Default.ParentNode}) to get access to the properties. */ type ParentNode = Default.ParentNode | HtmlParser2.ParentNode | Object; /** * Generic DocumentType interface. * Cast to the actual AST interface (e.g. {@link parse5.AST.Default.DocumentType}) to get access to the properties. */ type DocumentType = Default.DocumentType | HtmlParser2.DocumentType | Object; /** * Generic Document interface. * Cast to the actual AST interface (e.g. {@link parse5.AST.Default.Document}) to get access to the properties. */ type Document = Default.Document | HtmlParser2.Document | Object; /** * Generic DocumentFragment interface. * Cast to the actual AST interface (e.g. {@link parse5.AST.Default.DocumentFragment}) to get access to the properties. */ type DocumentFragment = Default.DocumentFragment | HtmlParser2.DocumentFragment | Object; /** * Generic Element interface. * Cast to the actual AST interface (e.g. {@link parse5.AST.Default.Element}) to get access to the properties. */ type Element = Default.Element | HtmlParser2.Element | Object; /** * Generic TextNode interface. * Cast to the actual AST interface (e.g. {@link parse5.AST.Default.TextNode}) to get access to the properties. */ type TextNode = Default.TextNode | HtmlParser2.TextNode | Object; /** * Generic CommentNode interface. * Cast to the actual AST interface (e.g. {@link parse5.AST.Default.CommentNode}) to get access to the properties. */ type CommentNode = Default.CommentNode | HtmlParser2.CommentNode | Object; // Tree adapter interface //----------------------------------------------------------------------------------- /** * Tree adapter is a set of utility functions that provides minimal required abstraction layer beetween parser and a specific AST format. * Note that `TreeAdapter` is not designed to be a general purpose AST manipulation library. You can build such library * on top of existing `TreeAdapter` or use one of the existing libraries from npm. * * @see [default implementation](https://github.com/inikulin/parse5/blob/master/lib/tree_adapters/default.js) */ export interface TreeAdapter { /** * Creates a document node. */ createDocument(): AST.Document; /** * Creates a document fragment node. */ createDocumentFragment(): AST.DocumentFragment; /** * Creates an element node. * * @param tagName - Tag name of the element. * @param namespaceURI - Namespace of the element. * @param attrs - Attribute name-value pair array. Foreign attributes may contain `namespace` and `prefix` fields as well. */ createElement(tagName: string, namespaceURI: string, attrs: AST.Default.Attribute[]): AST.Element; /** * Creates a comment node. * * @param data - Comment text. */ createCommentNode(data: string): AST.CommentNode; /** * Appends a child node to the given parent node. * * @param parentNode - Parent node. * @param newNode - Child node. */ appendChild(parentNode: AST.ParentNode, newNode: AST.Node): void; /** * Inserts a child node to the given parent node before the given reference node. * * @param parentNode - Parent node. * @param newNode - Child node. * @param referenceNode - Reference node. */ insertBefore(parentNode: AST.ParentNode, newNode: AST.Node, referenceNode: AST.Node): void; /** * Sets the `<template>` element content element. * * @param templateElement - `<template>` element. * @param contentElement - Content element. */ setTemplateContent(templateElement: AST.Element, contentElement: AST.DocumentFragment): void; /** * Returns the `<template>` element content element. * * @param templateElement - `<template>` element. */ getTemplateContent(templateElement: AST.Element): AST.DocumentFragment; /** * Sets the document type. If the `document` already contains a document type node, the `name`, `publicId` and `systemId` * properties of this node will be updated with the provided values. Otherwise, creates a new document type node * with the given properties and inserts it into the `document`. * * @param document - Document node. * @param name - Document type name. * @param publicId - Document type public identifier. * @param systemId - Document type system identifier. */ setDocumentType(document: AST.Document, name: string, publicId: string, systemId: string): void; /** * Sets the [document mode](https://dom.spec.whatwg.org/#concept-document-limited-quirks). * * @param document - Document node. * @param mode - Document mode. */ setDocumentMode(document: AST.Document, mode: AST.DocumentMode): void; /** * Returns [document mode](https://dom.spec.whatwg.org/#concept-document-limited-quirks). * * @param document - Document node. */ getDocumentMode(document: AST.Document): AST.DocumentMode; /** * Removes a node from its parent. * * @param node - Node to remove. */ detachNode(node: AST.Node): void; /** * Inserts text into a node. If the last child of the node is a text node, the provided text will be appended to the * text node content. Otherwise, inserts a new text node with the given text. * * @param parentNode - Node to insert text into. * @param text - Text to insert. */ insertText(parentNode: AST.ParentNode, text: string): void; /** * Inserts text into a sibling node that goes before the reference node. If this sibling node is the text node, * the provided text will be appended to the text node content. Otherwise, inserts a new sibling text node with * the given text before the reference node. * * @param parentNode - Node to insert text into. * @param text - Text to insert. * @param referenceNode - Node to insert text before. */ insertTextBefore(parentNode: AST.ParentNode, text: string, referenceNode: AST.Node): void; /** * Copies attributes to the given element. Only attributes that are not yet present in the element are copied. * * @param recipient - Element to copy attributes into. * @param attrs - Attributes to copy. */ adoptAttributes(recipient: AST.Element, attrs: AST.Default.Attribute[]): void; /** * Returns the first child of the given node. * * @param node - Node. */ getFirstChild(node: AST.ParentNode): AST.Node; /** * Returns the given node's children in an array. * * @param node - Node. */ getChildNodes(node: AST.ParentNode): AST.Node[]; /** * Returns the given node's parent. * * @param node - Node. */ getParentNode(node: AST.Node): AST.ParentNode; /** * Returns the given element's attributes in an array, in the form of name-value pairs. * Foreign attributes may contain `namespace` and `prefix` fields as well. * * @param element - Element. */ getAttrList(element: AST.Element): AST.Default.Attribute[]; /** * Returns the given element's tag name. * * @param element - Element. */ getTagName(element: AST.Element): string; /** * Returns the given element's namespace. * * @param element - Element. */ getNamespaceURI(element: AST.Element): string; /** * Returns the given text node's content. * * @param textNode - Text node. */ getTextNodeContent(textNode: AST.TextNode): string; /** * Returns the given comment node's content. * * @param commentNode - Comment node. */ getCommentNodeContent(commentNode: AST.CommentNode): string; /** * Returns the given document type node's name. * * @param doctypeNode - Document type node. */ getDocumentTypeNodeName(doctypeNode: AST.DocumentType): string; /** * Returns the given document type node's public identifier. * * @param doctypeNode - Document type node. */ getDocumentTypeNodePublicId(doctypeNode: AST.DocumentType): string; /** * Returns the given document type node's system identifier. * * @param doctypeNode - Document type node. */ getDocumentTypeNodeSystemId(doctypeNode: AST.DocumentType): string; /** * Determines if the given node is a text node. * * @param node - Node. */ isTextNode(node: AST.Node): boolean; /** * Determines if the given node is a comment node. * * @param node - Node. */ isCommentNode(node: AST.Node): boolean; /** * Determines if the given node is a document type node. * * @param node - Node. */ isDocumentTypeNode(node: AST.Node): boolean; /** * Determines if the given node is an element. * * @param node - Node. */ isElementNode(node: AST.Node): boolean; } } // Included tree adapters //----------------------------------------------------------------------------------- /** * Provides built-in tree adapters that can be used for parsing and serialization. * * @example *```js * * const parse5 = require('parse5'); * * // Uses the default tree adapter for parsing. * const document = parse5.parse('<div></div>', { * treeAdapter: parse5.treeAdapters.default * }); * * // Uses the htmlparser2 tree adapter with the SerializerStream. * const serializer = new parse5.SerializerStream(node, { * treeAdapter: parse5.treeAdapters.htmlparser2 * }); * ``` */ export var treeAdapters: { /** * Default tree format for parse5. */ default: AST.TreeAdapter, /** * Quite popular [htmlparser2](https://github.com/fb55/htmlparser2) tree format * (e.g. used by [cheerio](https://github.com/MatthewMueller/cheerio) and [jsdom](https://github.com/tmpvar/jsdom)). */ htmlparser2: AST.TreeAdapter }; // Shorthand methods //----------------------------------------------------------------------------------- /** * Parses an HTML string. * * @param html - Input HTML string. * @param options - Parsing options. * * @example * ```js * * const parse5 = require('parse5'); * * const document = parse5.parse('<!DOCTYPE html><html><head></head><body>Hi there!</body></html>'); * * console.log(document.childNodes[1].tagName); //> 'html' * ``` */ export function parse(html: string, options?: Options.ParserOptions): AST.Document; /** * Parses an HTML fragment. * * @param fragmentContext - Parsing context element. If specified, given fragment will be parsed as if it was set to the context element's `innerHTML` property. * @param html - Input HTML fragment string. * @param options - Parsing options. * * @example * ```js * * const parse5 = require('parse5'); * * const documentFragment = parse5.parseFragment('<table></table>'); * * console.log(documentFragment.childNodes[0].tagName); //> 'table' * * // Parses the html fragment in the context of the parsed <table> element. * const trFragment = parser.parseFragment(documentFragment.childNodes[0], '<tr><td>Shake it, baby</td></tr>'); * * console.log(trFragment.childNodes[0].childNodes[0].tagName); //> 'td' * ``` */ export function parseFragment(fragmentContext: AST.Element, html: string, options?: Options.ParserOptions): AST.DocumentFragment; export function parseFragment(html: string, options?: Options.ParserOptions): AST.DocumentFragment; /** * Serializes an AST node to an HTML string. * * @param node - Node to serialize. * @param options - Serialization options. * * @example * ```js * * const parse5 = require('parse5'); * * const document = parse5.parse('<!DOCTYPE html><html><head></head><body>Hi there!</body></html>'); * * // Serializes a document. * const html = parse5.serialize(document); * * // Serializes the <html> element content. * const str = parse5.serialize(document.childNodes[1]); * * console.log(str); //> '<head></head><body>Hi there!</body>' * ``` */ export function serialize(node: AST.Node, options?: Options.SerializerOptions): string; // Parser stream //----------------------------------------------------------------------------------- /** * Streaming HTML parser with scripting support. * A [writable stream](https://nodejs.org/api/stream.html#stream_class_stream_writable). * * ** NOTE:** This API is available only for Node.js. * * @example * ```js * * const parse5 = require('parse5'); * const http = require('http'); * * // Fetch the page content and obtain it's <head> node * http.get('http://inikulin.github.io/parse5/', res => { * const parser = new parse5.ParserStream(); * * parser.once('finish', () => { * console.log(parser.document.childNodes[1].childNodes[0].tagName); //> 'head' * }); * * res.pipe(parser); * }); * ``` */ export class ParserStream extends stream.Writable { /** * @param options - Parsing options. */ constructor(options?: Options.ParserOptions); /** * The resulting document node. */ document: AST.Document; /** * Raised then parser encounters a `<script>` element. * If this event has listeners, parsing will be suspended once it is emitted. * So, if `<script>` has the `src` attribute, you can fetch it, execute and then resume parsing just like browsers do. * * @param listener.scriptElement - The script element that caused the event. * @param listener.documentWrite - Write additional `html` at the current parsing position. Suitable for implementing the DOM `document.write` and `document.writeln` methods. * @param listener.documentWrite.html - HTML to write. * @param listener.resume - Resumes parsing. * * @example * ```js * * const parse = require('parse5'); * const http = require('http'); * * const parser = new parse5.ParserStream(); * * parser.on('script', (scriptElement, documentWrite, resume) => { * const src = parse5.treeAdapters.default.getAttrList(scriptElement)[0].value; * * http.get(src, res => { * // Fetch the script content, execute it with DOM built around `parser.document` and * // `document.write` implemented using `documentWrite`. * ... * // Then resume parsing. * resume(); * }); * }); * * parser.end('<script src="example.com/script.js"></script>'); * ``` */ on(event: 'script', listener: (scriptElement: AST.Element, documentWrite: (html: string) => void, resume: () => void) => void): this; /** * WritableStream events */ on(event: string, listener: Function): this; } // Plaint text conversion stream //----------------------------------------------------------------------------------- /** * Converts plain text files into HTML document as required by [HTML specification](https://html.spec.whatwg.org/#read-text). * A [writable stream](https://nodejs.org/api/stream.html#stream_class_stream_writable). * * ** NOTE:** This API is available only for Node.js. * * @example * ```js * * const parse5 = require('parse5'); * const fs = require('fs'); * * const file = fs.createReadStream('war_and_peace.txt'); * const converter = new parse5.PlainTextConversionStream(); * * converter.once('finish', () => { * console.log(converter.document.childNodes[1].childNodes[0].tagName); //> 'head' * }); * * file.pipe(converter); * ``` */ export class PlainTextConversionStream extends ParserStream { } // SAX parser //----------------------------------------------------------------------------------- /** * Streaming [SAX](https://en.wikipedia.org/wiki/Simple_API_for_XML)-style HTML parser. * A [transform stream](https://nodejs.org/api/stream.html#stream_class_stream_transform) * (which means you can pipe *through* it, see example). * * ** NOTE:** This API is available only for Node.js. * * @example * ```js * * const parse5 = require('parse5'); * const http = require('http'); * const fs = require('fs'); * * const file = fs.createWriteStream('/home/google.com.html'); * const parser = new parse5.SAXParser(); * * parser.on('text', text => { * // Handle page text content * ... * }); * * http.get('http://google.com', res => { * // SAXParser is the Transform stream, which means you can pipe * // through it. So, you can analyze page content and, e.g., save it * // to the file at the same time: * res.pipe(parser).pipe(file); * }); * ``` */ export class SAXParser extends stream.Transform { /** * @param options - Parsing options. */ constructor(options?: Options.SAXParserOptions); /** * Raised when the parser encounters a start tag. * * @param listener.name - Tag name. * @param listener.attrs - List of attributes. * @param listener.selfClosing - Indicates if the tag is self-closing. * @param listener.location - Start tag source code location info. Available if location info is enabled via {@link Options.SAXParserOptions}. */ on(event: 'startTag', listener: (name: string, attrs: AST.Default.Attribute[], selfClosing: boolean, location?: MarkupData.StartTagLocation) => void): this; /** * Raised then parser encounters an end tag. * * @param listener.name - Tag name. * @param listener.location - End tag source code location info. Available if location info is enabled via {@link Options.SAXParserOptions}. */ on(event: 'endTag', listener: (name: string, location?: MarkupData.Location) => void): this; /** * Raised then parser encounters a comment. * * @param listener.text - Comment text. * @param listener.location - Comment source code location info. Available if location info is enabled via {@link Options.SAXParserOptions}. */ on(event: 'comment', listener: (text: string, location?: MarkupData.Location) => void): this; /** * Raised then parser encounters text content. * * @param listener.text - Text content. * @param listener.location - Text content code location info. Available if location info is enabled via {@link Options.SAXParserOptions}. */ on(event: 'text', listener: (text: string, location?: MarkupData.Location) => void): this; /** * Raised then parser encounters a [document type declaration](https://en.wikipedia.org/wiki/Document_type_declaration). * * @param listener.name - Document type name. * @param listener.publicId - Document type public identifier. * @param listener.systemId - Document type system identifier. * @param listener.location - Document type declaration source code location info. Available if location info is enabled via {@link Options.SAXParserOptions}. */ on(event: 'doctype', listener: (name: string, publicId: string, systemId: string, location?: MarkupData.Location) => void): this; /** * TransformStream events */ on(event: string, listener: Function): this; /** * Stops parsing. Useful if you want the parser to stop consuming CPU time once you've obtained the desired info * from the input stream. Doesn't prevent piping, so that data will flow through the parser as usual. * * @example * ```js * * const parse5 = require('parse5'); * const http = require('http'); * const fs = require('fs'); * * const file = fs.createWriteStream('google.com.html'); * const parser = new parse5.SAXParser(); * * parser.on('doctype', (name, publicId, systemId) => { * // Process doctype info ans stop parsing * ... * parser.stop(); * }); * * http.get('http://google.com', res => { * // Despite the fact that parser.stop() was called whole * // content of the page will be written to the file * res.pipe(parser).pipe(file); * }); * ``` */ stop(): void; } // Serializer stream //----------------------------------------------------------------------------------- /** * Streaming AST node to an HTML serializer. * A [readable stream](https://nodejs.org/api/stream.html#stream_class_stream_readable). * * ** NOTE:** This API is available only for Node.js. * * @example * ```js * * const parse5 = require('parse5'); * const fs = require('fs'); * * const file = fs.createWriteStream('/home/index.html'); * * // Serializes the parsed document to HTML and writes it to the file. * const document = parse5.parse('<body>Who is John Galt?</body>'); * const serializer = new parse5.SerializerStream(document); * * serializer.pipe(file); * ``` */ export class SerializerStream extends stream.Readable { /** * Streaming AST node to an HTML serializer. A readable stream. * * @param node - Node to serialize. * @param options - Serialization options. */ constructor(node: AST.Node, options?: Options.SerializerOptions); }