summaryrefslogtreecommitdiff
path: root/school/node_modules/saxes/saxes.d.ts
diff options
context:
space:
mode:
authorMinteck <contact@minteck.org>2023-01-10 14:54:04 +0100
committerMinteck <contact@minteck.org>2023-01-10 14:54:04 +0100
commit99c1d9af689e5325f3cf535c4007b3aeb8325229 (patch)
treee663b3c2ebdbd67c818ac0c5147f0ce1d2463cda /school/node_modules/saxes/saxes.d.ts
parent9871b03912fc28ad38b4037ebf26a78aa937baba (diff)
downloadpluralconnect-99c1d9af689e5325f3cf535c4007b3aeb8325229.tar.gz
pluralconnect-99c1d9af689e5325f3cf535c4007b3aeb8325229.tar.bz2
pluralconnect-99c1d9af689e5325f3cf535c4007b3aeb8325229.zip
Update - This is an automated commit
Diffstat (limited to 'school/node_modules/saxes/saxes.d.ts')
-rw-r--r--school/node_modules/saxes/saxes.d.ts635
1 files changed, 635 insertions, 0 deletions
diff --git a/school/node_modules/saxes/saxes.d.ts b/school/node_modules/saxes/saxes.d.ts
new file mode 100644
index 0000000..41c101f
--- /dev/null
+++ b/school/node_modules/saxes/saxes.d.ts
@@ -0,0 +1,635 @@
+/**
+ * The list of supported events.
+ */
+export declare const EVENTS: readonly ["xmldecl", "text", "processinginstruction", "doctype", "comment", "opentagstart", "attribute", "opentag", "closetag", "cdata", "error", "end", "ready"];
+/**
+ * Event handler for the
+ *
+ * @param text The text data encountered by the parser.
+ *
+ */
+export declare type XMLDeclHandler = (decl: XMLDecl) => void;
+/**
+ * Event handler for text data.
+ *
+ * @param text The text data encountered by the parser.
+ *
+ */
+export declare type TextHandler = (text: string) => void;
+/**
+ * Event handler for processing instructions.
+ *
+ * @param data The target and body of the processing instruction.
+ */
+export declare type PIHandler = (data: {
+ target: string;
+ body: string;
+}) => void;
+/**
+ * Event handler for doctype.
+ *
+ * @param doctype The doctype contents.
+ */
+export declare type DoctypeHandler = (doctype: string) => void;
+/**
+ * Event handler for comments.
+ *
+ * @param comment The comment contents.
+ */
+export declare type CommentHandler = (comment: string) => void;
+/**
+ * Event handler for the start of an open tag. This is called as soon as we
+ * have a tag name.
+ *
+ * @param tag The tag.
+ */
+export declare type OpenTagStartHandler<O> = (tag: StartTagForOptions<O>) => void;
+export declare type AttributeEventForOptions<O extends SaxesOptions> = O extends {
+ xmlns: true;
+} ? SaxesAttributeNSIncomplete : O extends {
+ xmlns?: false | undefined;
+} ? SaxesAttributePlain : SaxesAttribute;
+/**
+ * Event handler for attributes.
+ */
+export declare type AttributeHandler<O> = (attribute: AttributeEventForOptions<O>) => void;
+/**
+ * Event handler for an open tag. This is called when the open tag is
+ * complete. (We've encountered the ">" that ends the open tag.)
+ *
+ * @param tag The tag.
+ */
+export declare type OpenTagHandler<O> = (tag: TagForOptions<O>) => void;
+/**
+ * Event handler for a close tag. Note that for self-closing tags, this is
+ * called right after ``opentag``.
+ *
+ * @param tag The tag.
+ */
+export declare type CloseTagHandler<O> = (tag: TagForOptions<O>) => void;
+/**
+ * Event handler for a CDATA section. This is called when ending the
+ * CDATA section.
+ *
+ * @param cdata The contents of the CDATA section.
+ */
+export declare type CDataHandler = (cdata: string) => void;
+/**
+ * Event handler for the stream end. This is called when the stream has been
+ * closed with ``close`` or by passing ``null`` to ``write``.
+ */
+export declare type EndHandler = () => void;
+/**
+ * Event handler indicating parser readiness . This is called when the parser
+ * is ready to parse a new document.
+ */
+export declare type ReadyHandler = () => void;
+/**
+ * Event handler indicating an error.
+ *
+ * @param err The error that occurred.
+ */
+export declare type ErrorHandler = (err: Error) => void;
+export declare type EventName = (typeof EVENTS)[number];
+export declare type EventNameToHandler<O, N extends EventName> = {
+ "xmldecl": XMLDeclHandler;
+ "text": TextHandler;
+ "processinginstruction": PIHandler;
+ "doctype": DoctypeHandler;
+ "comment": CommentHandler;
+ "opentagstart": OpenTagStartHandler<O>;
+ "attribute": AttributeHandler<O>;
+ "opentag": OpenTagHandler<O>;
+ "closetag": CloseTagHandler<O>;
+ "cdata": CDataHandler;
+ "error": ErrorHandler;
+ "end": EndHandler;
+ "ready": ReadyHandler;
+}[N];
+/**
+ * This interface defines the structure of attributes when the parser is
+ * processing namespaces (created with ``xmlns: true``).
+ */
+export interface SaxesAttributeNS {
+ /**
+ * The attribute's name. This is the combination of prefix and local name.
+ * For instance ``a:b="c"`` would have ``a:b`` for name.
+ */
+ name: string;
+ /**
+ * The attribute's prefix. For instance ``a:b="c"`` would have ``"a"`` for
+ * ``prefix``.
+ */
+ prefix: string;
+ /**
+ * The attribute's local name. For instance ``a:b="c"`` would have ``"b"`` for
+ * ``local``.
+ */
+ local: string;
+ /** The namespace URI of this attribute. */
+ uri: string;
+ /** The attribute's value. */
+ value: string;
+}
+/**
+ * This is an attribute, as recorded by a parser which parses namespaces but
+ * prior to the URI being resolvable. This is what is passed to the attribute
+ * event handler.
+ */
+export declare type SaxesAttributeNSIncomplete = Exclude<SaxesAttributeNS, "uri">;
+/**
+ * This interface defines the structure of attributes when the parser is
+ * NOT processing namespaces (created with ``xmlns: false``).
+ */
+export interface SaxesAttributePlain {
+ /**
+ * The attribute's name.
+ */
+ name: string;
+ /** The attribute's value. */
+ value: string;
+}
+/**
+ * A saxes attribute, with or without namespace information.
+ */
+export declare type SaxesAttribute = SaxesAttributeNS | SaxesAttributePlain;
+/**
+ * This are the fields that MAY be present on a complete tag.
+ */
+export interface SaxesTag {
+ /**
+ * The tag's name. This is the combination of prefix and global name. For
+ * instance ``<a:b>`` would have ``"a:b"`` for ``name``.
+ */
+ name: string;
+ /**
+ * A map of attribute name to attributes. If namespaces are tracked, the
+ * values in the map are attribute objects. Otherwise, they are strings.
+ */
+ attributes: Record<string, SaxesAttributeNS> | Record<string, string>;
+ /**
+ * The namespace bindings in effect.
+ */
+ ns?: Record<string, string>;
+ /**
+ * The tag's prefix. For instance ``<a:b>`` would have ``"a"`` for
+ * ``prefix``. Undefined if we do not track namespaces.
+ */
+ prefix?: string;
+ /**
+ * The tag's local name. For instance ``<a:b>`` would
+ * have ``"b"`` for ``local``. Undefined if we do not track namespaces.
+ */
+ local?: string;
+ /**
+ * The namespace URI of this tag. Undefined if we do not track namespaces.
+ */
+ uri?: string;
+ /** Whether the tag is self-closing (e.g. ``<foo/>``). */
+ isSelfClosing: boolean;
+}
+/**
+ * This type defines the fields that are present on a tag object when
+ * ``onopentagstart`` is called. This interface is namespace-agnostic.
+ */
+export declare type SaxesStartTag = Pick<SaxesTag, "name" | "attributes" | "ns">;
+/**
+ * This type defines the fields that are present on a tag object when
+ * ``onopentagstart`` is called on a parser that does not processes namespaces.
+ */
+export declare type SaxesStartTagPlain = Pick<SaxesStartTag, "name" | "attributes">;
+/**
+ * This type defines the fields that are present on a tag object when
+ * ``onopentagstart`` is called on a parser that does process namespaces.
+ */
+export declare type SaxesStartTagNS = Required<SaxesStartTag>;
+/**
+ * This are the fields that are present on a complete tag produced by a parser
+ * that does process namespaces.
+ */
+export declare type SaxesTagNS = Required<SaxesTag> & {
+ attributes: Record<string, SaxesAttributeNS>;
+};
+/**
+ * This are the fields that are present on a complete tag produced by a parser
+ * that does not process namespaces.
+ */
+export declare type SaxesTagPlain = Pick<SaxesTag, "name" | "attributes" | "isSelfClosing"> & {
+ attributes: Record<string, string>;
+};
+/**
+ * An XML declaration.
+ */
+export interface XMLDecl {
+ /** The version specified by the XML declaration. */
+ version?: string;
+ /** The encoding specified by the XML declaration. */
+ encoding?: string;
+ /** The value of the standalone parameter */
+ standalone?: string;
+}
+/**
+ * A callback for resolving name prefixes.
+ *
+ * @param prefix The prefix to check.
+ *
+ * @returns The URI corresponding to the prefix, if any.
+ */
+export declare type ResolvePrefix = (prefix: string) => string | undefined;
+export interface CommonOptions {
+ /** Whether to accept XML fragments. Unset means ``false``. */
+ fragment?: boolean;
+ /** Whether to track positions. Unset means ``true``. */
+ position?: boolean;
+ /**
+ * A file name to use for error reporting. "File name" is a loose concept. You
+ * could use a URL to some resource, or any descriptive name you like.
+ */
+ fileName?: string;
+}
+export interface NSOptions {
+ /** Whether to track namespaces. Unset means ``false``. */
+ xmlns?: boolean;
+ /**
+ * A plain object whose key, value pairs define namespaces known before
+ * parsing the XML file. It is not legal to pass bindings for the namespaces
+ * ``"xml"`` or ``"xmlns"``.
+ */
+ additionalNamespaces?: Record<string, string>;
+ /**
+ * A function that will be used if the parser cannot resolve a namespace
+ * prefix on its own.
+ */
+ resolvePrefix?: ResolvePrefix;
+}
+export interface NSOptionsWithoutNamespaces extends NSOptions {
+ xmlns?: false;
+ additionalNamespaces?: undefined;
+ resolvePrefix?: undefined;
+}
+export interface NSOptionsWithNamespaces extends NSOptions {
+ xmlns: true;
+}
+export interface XMLVersionOptions {
+ /**
+ * The default XML version to use. If unspecified, and there is no XML
+ * encoding declaration, the default version is "1.0".
+ */
+ defaultXMLVersion?: "1.0" | "1.1";
+ /**
+ * A flag indicating whether to force the XML version used for parsing to the
+ * value of ``defaultXMLVersion``. When this flag is ``true``,
+ * ``defaultXMLVersion`` must be specified. If unspecified, the default value
+ * of this flag is ``false``.
+ */
+ forceXMLVersion?: boolean;
+}
+export interface NoForcedXMLVersion extends XMLVersionOptions {
+ forceXMLVersion?: false;
+}
+export interface ForcedXMLVersion extends XMLVersionOptions {
+ forceXMLVersion: true;
+ defaultXMLVersion: Exclude<XMLVersionOptions["defaultXMLVersion"], undefined>;
+}
+/**
+ * The entire set of options supported by saxes.
+ */
+export declare type SaxesOptions = CommonOptions & NSOptions & XMLVersionOptions;
+export declare type TagForOptions<O extends SaxesOptions> = O extends {
+ xmlns: true;
+} ? SaxesTagNS : O extends {
+ xmlns?: false | undefined;
+} ? SaxesTagPlain : SaxesTag;
+export declare type StartTagForOptions<O extends SaxesOptions> = O extends {
+ xmlns: true;
+} ? SaxesStartTagNS : O extends {
+ xmlns?: false | undefined;
+} ? SaxesStartTagPlain : SaxesStartTag;
+export declare class SaxesParser<O extends SaxesOptions = {}> {
+ private readonly fragmentOpt;
+ private readonly xmlnsOpt;
+ private readonly trackPosition;
+ private readonly fileName?;
+ private readonly nameStartCheck;
+ private readonly nameCheck;
+ private readonly isName;
+ private readonly ns;
+ private openWakaBang;
+ private text;
+ private name;
+ private piTarget;
+ private entity;
+ private q;
+ private tags;
+ private tag;
+ private topNS;
+ private chunk;
+ private chunkPosition;
+ private i;
+ private prevI;
+ private carriedFromPrevious?;
+ private forbiddenState;
+ private attribList;
+ private state;
+ private reportedTextBeforeRoot;
+ private reportedTextAfterRoot;
+ private closedRoot;
+ private sawRoot;
+ private xmlDeclPossible;
+ private xmlDeclExpects;
+ private entityReturnState?;
+ private processAttribs;
+ private positionAtNewLine;
+ private doctype;
+ private getCode;
+ private isChar;
+ private pushAttrib;
+ private _closed;
+ private currentXMLVersion;
+ private readonly stateTable;
+ private xmldeclHandler?;
+ private textHandler?;
+ private piHandler?;
+ private doctypeHandler?;
+ private commentHandler?;
+ private openTagStartHandler?;
+ private openTagHandler?;
+ private closeTagHandler?;
+ private cdataHandler?;
+ private errorHandler?;
+ private endHandler?;
+ private readyHandler?;
+ private attributeHandler?;
+ /**
+ * Indicates whether or not the parser is closed. If ``true``, wait for
+ * the ``ready`` event to write again.
+ */
+ get closed(): boolean;
+ readonly opt: SaxesOptions;
+ /**
+ * The XML declaration for this document.
+ */
+ xmlDecl: XMLDecl;
+ /**
+ * The line number of the next character to be read by the parser. This field
+ * is one-based. (The first line is numbered 1.)
+ */
+ line: number;
+ /**
+ * The column number of the next character to be read by the parser. *
+ * This field is zero-based. (The first column is 0.)
+ *
+ * This field counts columns by *Unicode character*. Note that this *can*
+ * be different from the index of the character in a JavaScript string due
+ * to how JavaScript handles astral plane characters.
+ *
+ * See [[columnIndex]] for a number that corresponds to the JavaScript index.
+ */
+ column: number;
+ /**
+ * A map of entity name to expansion.
+ */
+ ENTITIES: Record<string, string>;
+ /**
+ * @param opt The parser options.
+ */
+ constructor(opt?: O);
+ _init(): void;
+ /**
+ * The stream position the parser is currently looking at. This field is
+ * zero-based.
+ *
+ * This field is not based on counting Unicode characters but is to be
+ * interpreted as a plain index into a JavaScript string.
+ */
+ get position(): number;
+ /**
+ * The column number of the next character to be read by the parser. *
+ * This field is zero-based. (The first column in a line is 0.)
+ *
+ * This field reports the index at which the next character would be in the
+ * line if the line were represented as a JavaScript string. Note that this
+ * *can* be different to a count based on the number of *Unicode characters*
+ * due to how JavaScript handles astral plane characters.
+ *
+ * See [[column]] for a number that corresponds to a count of Unicode
+ * characters.
+ */
+ get columnIndex(): number;
+ /**
+ * Set an event listener on an event. The parser supports one handler per
+ * event type. If you try to set an event handler over an existing handler,
+ * the old handler is silently overwritten.
+ *
+ * @param name The event to listen to.
+ *
+ * @param handler The handler to set.
+ */
+ on<N extends EventName>(name: N, handler: EventNameToHandler<O, N>): void;
+ /**
+ * Unset an event handler.
+ *
+ * @parma name The event to stop listening to.
+ */
+ off(name: EventName): void;
+ /**
+ * Make an error object. The error object will have a message that contains
+ * the ``fileName`` option passed at the creation of the parser. If position
+ * tracking was turned on, it will also have line and column number
+ * information.
+ *
+ * @param message The message describing the error to report.
+ *
+ * @returns An error object with a properly formatted message.
+ */
+ makeError(message: string): Error;
+ /**
+ * Report a parsing error. This method is made public so that client code may
+ * check for issues that are outside the scope of this project and can report
+ * errors.
+ *
+ * @param message The error to report.
+ *
+ * @returns this
+ */
+ fail(message: string): this;
+ /**
+ * Write a XML data to the parser.
+ *
+ * @param chunk The XML data to write.
+ *
+ * @returns this
+ */
+ write(chunk: string | {} | null): this;
+ /**
+ * Close the current stream. Perform final well-formedness checks and reset
+ * the parser tstate.
+ *
+ * @returns this
+ */
+ close(): this;
+ /**
+ * Get a single code point out of the current chunk. This updates the current
+ * position if we do position tracking.
+ *
+ * This is the algorithm to use for XML 1.0.
+ *
+ * @returns The character read.
+ */
+ private getCode10;
+ /**
+ * Get a single code point out of the current chunk. This updates the current
+ * position if we do position tracking.
+ *
+ * This is the algorithm to use for XML 1.1.
+ *
+ * @returns {number} The character read.
+ */
+ private getCode11;
+ /**
+ * Like ``getCode`` but with the return value normalized so that ``NL`` is
+ * returned for ``NL_LIKE``.
+ */
+ private getCodeNorm;
+ private unget;
+ /**
+ * Capture characters into a buffer until encountering one of a set of
+ * characters.
+ *
+ * @param chars An array of codepoints. Encountering a character in the array
+ * ends the capture. (``chars`` may safely contain ``NL``.)
+ *
+ * @return The character code that made the capture end, or ``EOC`` if we hit
+ * the end of the chunk. The return value cannot be NL_LIKE: NL is returned
+ * instead.
+ */
+ private captureTo;
+ /**
+ * Capture characters into a buffer until encountering a character.
+ *
+ * @param char The codepoint that ends the capture. **NOTE ``char`` MAY NOT
+ * CONTAIN ``NL``.** Passing ``NL`` will result in buggy behavior.
+ *
+ * @return ``true`` if we ran into the character. Otherwise, we ran into the
+ * end of the current chunk.
+ */
+ private captureToChar;
+ /**
+ * Capture characters that satisfy ``isNameChar`` into the ``name`` field of
+ * this parser.
+ *
+ * @return The character code that made the test fail, or ``EOC`` if we hit
+ * the end of the chunk. The return value cannot be NL_LIKE: NL is returned
+ * instead.
+ */
+ private captureNameChars;
+ /**
+ * Skip white spaces.
+ *
+ * @return The character that ended the skip, or ``EOC`` if we hit
+ * the end of the chunk. The return value cannot be NL_LIKE: NL is returned
+ * instead.
+ */
+ private skipSpaces;
+ private setXMLVersion;
+ private sBegin;
+ private sBeginWhitespace;
+ private sDoctype;
+ private sDoctypeQuote;
+ private sDTD;
+ private sDTDQuoted;
+ private sDTDOpenWaka;
+ private sDTDOpenWakaBang;
+ private sDTDComment;
+ private sDTDCommentEnding;
+ private sDTDCommentEnded;
+ private sDTDPI;
+ private sDTDPIEnding;
+ private sText;
+ private sEntity;
+ private sOpenWaka;
+ private sOpenWakaBang;
+ private sComment;
+ private sCommentEnding;
+ private sCommentEnded;
+ private sCData;
+ private sCDataEnding;
+ private sCDataEnding2;
+ private sPIFirstChar;
+ private sPIRest;
+ private sPIBody;
+ private sPIEnding;
+ private sXMLDeclNameStart;
+ private sXMLDeclName;
+ private sXMLDeclEq;
+ private sXMLDeclValueStart;
+ private sXMLDeclValue;
+ private sXMLDeclSeparator;
+ private sXMLDeclEnding;
+ private sOpenTag;
+ private sOpenTagSlash;
+ private sAttrib;
+ private sAttribName;
+ private sAttribNameSawWhite;
+ private sAttribValue;
+ private sAttribValueQuoted;
+ private sAttribValueClosed;
+ private sAttribValueUnquoted;
+ private sCloseTag;
+ private sCloseTagSawWhite;
+ private handleTextInRoot;
+ private handleTextOutsideRoot;
+ private pushAttribNS;
+ private pushAttribPlain;
+ /**
+ * End parsing. This performs final well-formedness checks and resets the
+ * parser to a clean state.
+ *
+ * @returns this
+ */
+ private end;
+ /**
+ * Resolve a namespace prefix.
+ *
+ * @param prefix The prefix to resolve.
+ *
+ * @returns The namespace URI or ``undefined`` if the prefix is not defined.
+ */
+ resolve(prefix: string): string | undefined;
+ /**
+ * Parse a qname into its prefix and local name parts.
+ *
+ * @param name The name to parse
+ *
+ * @returns
+ */
+ private qname;
+ private processAttribsNS;
+ private processAttribsPlain;
+ /**
+ * Handle a complete open tag. This parser code calls this once it has seen
+ * the whole tag. This method checks for well-formeness and then emits
+ * ``onopentag``.
+ */
+ private openTag;
+ /**
+ * Handle a complete self-closing tag. This parser code calls this once it has
+ * seen the whole tag. This method checks for well-formeness and then emits
+ * ``onopentag`` and ``onclosetag``.
+ */
+ private openSelfClosingTag;
+ /**
+ * Handle a complete close tag. This parser code calls this once it has seen
+ * the whole tag. This method checks for well-formeness and then emits
+ * ``onclosetag``.
+ */
+ private closeTag;
+ /**
+ * Resolves an entity. Makes any necessary well-formedness checks.
+ *
+ * @param entity The entity to resolve.
+ *
+ * @returns The parsed entity.
+ */
+ private parseEntity;
+}