mirror of
https://github.com/gosticks/DefinitelyTyped.git
synced 2025-10-16 12:05:41 +00:00
Important changes of the v0.18 version: - The previous libxmljs-tests.ts file used a require, thus made any variable from the imported 'libxmljs' typed 'any'. Hence, the test file actually tested no type declarations at all. This has been fixed via an ordinary 'import' statement. - Enabled strict null checks in tsconfig.json - Removed some exported classes (such as XMLDocument, HTMLDocument) which are neither used nor exported anymore in more recent libxmljs versions. - Added null return values to functions which sometimes return null, e.g. prevSibling(): Node|null.
174 lines
4.8 KiB
TypeScript
174 lines
4.8 KiB
TypeScript
// Type definitions for Libxmljs 0.18
|
|
// Project: https://github.com/libxmljs/libxmljs
|
|
// Definitions by: François de Campredon <https://github.com/fdecampredon>
|
|
// ComFreek <https://github.com/ComFreek>
|
|
// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped
|
|
|
|
/// <reference types="node"/>
|
|
import { EventEmitter } from 'events';
|
|
|
|
export const version: string;
|
|
export const libxml_version: string;
|
|
export const libxml_parser_version: string;
|
|
|
|
// tslint:disable-next-line:strict-export-declare-modifiers
|
|
interface ParseOptions {
|
|
[optionName: string]: string;
|
|
}
|
|
|
|
export function parseXml(source: string, options?: ParseOptions): Document;
|
|
export function parseXmlString(source: string, options?: ParseOptions): Document;
|
|
|
|
export function parseHtml(source: string, options?: ParseOptions): Document;
|
|
export function parseHtmlString(source: string, options?: ParseOptions): Document;
|
|
export function parseHtmlFragment(source: string, options?: ParseOptions): Document;
|
|
|
|
export function memoryUsage(): number;
|
|
export function nodeCount(): number;
|
|
|
|
export class Document {
|
|
/**
|
|
* Create a new XML Document
|
|
* @param version XML document version, defaults to 1.0
|
|
* @param encoding Encoding, defaults to utf8
|
|
*/
|
|
constructor(version?: number, encoding?: string);
|
|
|
|
errors: SyntaxError[];
|
|
|
|
child(idx: number): Element|null;
|
|
childNodes(): Element[];
|
|
encoding(): string;
|
|
encoding(enc: string): this;
|
|
find(xpath: string): Element[];
|
|
get(xpath: string): Element|null;
|
|
node(name: string, content?: string): Element;
|
|
root(): Element|null;
|
|
root(newRoot: Node): Node;
|
|
toString(formatted?: boolean): string;
|
|
type(): 'document';
|
|
version(): string;
|
|
setDtd(name: string, ext: string, sys: string): void;
|
|
getDtd(): {
|
|
name: string;
|
|
externalId: string;
|
|
systemId: string;
|
|
};
|
|
}
|
|
|
|
export class Node {
|
|
doc(): Document;
|
|
parent(): Element|Document;
|
|
/**
|
|
* The namespace or null in case of comment nodes
|
|
*/
|
|
namespace(): Namespace|null;
|
|
|
|
/**
|
|
* An array of namespaces that the object belongs to.
|
|
*
|
|
* @param local If it is true, only the namespace declarations local to this
|
|
* node are returned, rather than all of the namespaces in scope
|
|
* at this node (including the ones from the parent elements).
|
|
*/
|
|
namespaces(local?: boolean): Namespace[];
|
|
|
|
prevSibling(): Node|null;
|
|
nextSibling(): Node|null;
|
|
|
|
type(): 'comment'|'element'|'text'|'attribute';
|
|
remove(): this;
|
|
clone(): this;
|
|
/**
|
|
* Serializes the node to a string. The string will contain all contents of the node formatted as XML and can be used to print the node.
|
|
*/
|
|
toString(format?: boolean|{
|
|
declaration: boolean;
|
|
selfCloseEmpty: boolean;
|
|
whitespace: boolean;
|
|
type: 'xml'|'html'|'xhtml'
|
|
}): string;
|
|
}
|
|
|
|
export class Element extends Node {
|
|
constructor(doc: Document, name: string, content?: string);
|
|
node(name: string, content?: string): Element;
|
|
name(): string;
|
|
name(newName: string): this;
|
|
text(): string;
|
|
text(newText: string): this;
|
|
attr(name: string): Attribute|null;
|
|
attr(attrObject: { [key: string]: string; }): this;
|
|
attrs(): Attribute[];
|
|
|
|
doc(): Document;
|
|
child(idx: number): Node | null;
|
|
childNodes(): Node[];
|
|
|
|
/**
|
|
* @return The original element, not the child.
|
|
*/
|
|
addChild(child: Element): this;
|
|
|
|
prevElement(): Element|null;
|
|
nextElement(): Element|null;
|
|
addNextSibling(siblingNode: Node): Node;
|
|
|
|
find(xpath: string, ns_uri?: string): Node[];
|
|
find(xpath: string, namespaces: { [key: string]: string; }): Node[];
|
|
get(xpath: string, ns_uri?: string): Element|null;
|
|
|
|
defineNamespace(prefixOrHref: string, hrefInCaseOfPrefix?: string): Namespace;
|
|
|
|
namespace(): Namespace|null;
|
|
namespace(newNamespace: Namespace): this;
|
|
namespace(prefixOrHref: string, hrefInCaseOfPrefix?: string): Namespace;
|
|
|
|
replace(replacement: string): string;
|
|
replace(replacement: Element): Element;
|
|
|
|
path(): string;
|
|
}
|
|
|
|
export class Attribute {
|
|
name(): string;
|
|
value(): string;
|
|
value(newValue: string): Attribute;
|
|
namespace(): Namespace;
|
|
|
|
remove(): void;
|
|
}
|
|
|
|
export class Namespace {
|
|
href(): string;
|
|
prefix(): string;
|
|
}
|
|
|
|
export class SaxParser extends EventEmitter {
|
|
constructor();
|
|
parseString(source: string): boolean;
|
|
}
|
|
|
|
export class SaxPushParser extends EventEmitter {
|
|
constructor();
|
|
push(source: string): boolean;
|
|
}
|
|
|
|
export interface SyntaxError {
|
|
domain: number|null;
|
|
code: number|null;
|
|
message: string|null;
|
|
level: number|null;
|
|
file: string|null;
|
|
line: number|null;
|
|
/**
|
|
* 1-based column number, 0 if not applicable/available.
|
|
*/
|
|
column: number;
|
|
|
|
str1: number|null;
|
|
str2: number|null;
|
|
str3: number|null;
|
|
int1: number|null;
|
|
}
|