Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@citeproc-rs/wasm

Package Overview
Dependencies
Maintainers
1
Versions
48
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@citeproc-rs/wasm - npm Package Compare versions

Comparing version 0.0.0-canary-49bfd87 to 0.0.0-canary-502e4f0

_cjs/citeproc_rs_wasm_bg.wasm.d.ts

328

_cjs/citeproc_rs_wasm.d.ts
/* tslint:disable */
/* eslint-disable */
/**
* Parses a CSL style, either independent or dependent, and returns its metadata.
* @param {string} style
* @returns {WasmResult<StyleMeta>}
*/
export function parseStyleMetadata(style: string): WasmResult<StyleMeta>;
interface InitOptions {
/** A CSL style as an XML string */
style: string,
/** A Fetcher implementation for fetching locales.
*
* If not provided, then no locales can be fetched, and default-locale and localeOverride will
* not be respected; the only locale used will be the bundled en-US. */
fetcher?: Fetcher,
/** The output format for this driver instance */
format: "html" | "rtf" | "plain",
/** A locale to use instead of the style's default-locale.
*
* For dependent styles, use parseStyleMetadata to find out which locale it prefers, and pass
* in the parent style with a localeOverride set to that value.
*/
localeOverride?: string,
/** Disables sorting in the bibliography; items appear in cited order. */
bibliographyNoSort?: bool,
}
/** This interface lets citeproc retrieve locales or modules asynchronously,
according to which ones are needed. */
export interface Lifecycle {
export interface Fetcher {
/** Return locale XML for a particular locale. */

@@ -12,2 +41,4 @@ fetchLocale(lang: string): Promise<string>;

export type DateLiteral = { "literal": string; };

@@ -21,2 +52,4 @@ export type DateRaw = { "raw": string; };

/** Locator type, and a locator string */

@@ -29,16 +62,16 @@ export type Locator = {

export type CiteLocator = Locator | { locator: undefined; locators: Locator[] };
export type CiteLocator = Locator | { locator: undefined; locators: Locator[]; };
export type CiteMode = { mode?: "SuppressAuthor" | "AuthorOnly"; };
export type Cite<Affix = string> = {
export type Cite = {
id: string;
prefix?: Affix;
suffix?: Affix;
suppression?: "InText" | "Rest" | null;
} & Partial<CiteLocator>;
prefix?: string;
suffix?: string;
} & Partial<CiteLocator> & CiteMode;
export type ClusterNumber = {
note: number | [number, number]
} | {
inText: number
};
export type ClusterMode
= { mode: "Composite"; infix?: string; suppressFirst?: number; }
| { mode: "SuppressAuthor"; suppressFirst?: number; }
| { mode: "AuthorOnly"; }
| {};

@@ -48,4 +81,8 @@ export type Cluster = {

cites: Cite[];
};
} & ClusterMode;
export type PreviewCluster {
cites: Cite[];
} & ClusterMode;
export type ClusterPosition = {

@@ -57,2 +94,4 @@ id: string;

export type Reference = {

@@ -64,6 +103,8 @@ id: string;

export type CslType = "book" | "article" | "legal_case" | "article-journal";
export type CslType = "book" | "article" | "legal_case" | "article-journal" | string;
export interface BibliographyUpdate {
updatedEntries: { [key: string]: string };
updatedEntries: Map<string, string>;
entryIds?: string[];

@@ -77,19 +118,2 @@ }

type InvalidCsl = {
severity: "Error" | "Warning";
range: {
start: number;
end: number;
};
message: string;
hint: string;
};
type ParseError = {
ParseError: string;
};
type Invalid = {
Invalid: InvalidCsl[];
};
type StyleError = Partial<ParseError & Invalid>;
type IncludeUncited = "None" | "All" | { Specific: string[] };

@@ -105,3 +129,3 @@

type FullRender = {
allClusters: { [clusterId: string]: string },
allClusters: Map<string, string>,
bibEntries: BibEntries,

@@ -111,6 +135,6 @@ };

type BibliographyMeta = {
max_offset: number;
entry_spacing: number;
line_spacing: number;
hanging_indent: boolean;
maxOffset: number;
entrySpacing: number;
lineSpacing: number;
hangingIndent: boolean;
/** the second-field-align value of the CSL style */

@@ -123,2 +147,128 @@ secondFieldAlign: null | "flush" | "margin";

type Severity = "Error" | "Warning";
interface InvalidCsl {
severity: Severity;
/** Relevant bytes in the provided XML */
range: {
start: number,
end: number,
};
message: string;
hint: string | undefined;
};
type StyleError = {
tag: "Invalid",
content: InvalidCsl[],
} | {
tag: "ParseError",
content: string,
} | {
/** Cannot use a dependent style to format citations, pass the parent style instead. */
tag: "DependentStyle",
content: {
requiredParent: string,
}
};
type DriverError = {
tag: "UnknownOutputFormat",
content: string,
} | {
tag: "JsonError",
} | {
tag: "GetFetcherError",
} | {
tag: "NonExistentCluster",
content: string,
} | {
tag: "ReorderingError"
} | {
tag: "ReorderingErrorNumericId"
};
declare global {
/** Catch-all citeproc-rs Error subclass. */
declare class CiteprocRsError extends Error {
constructor(message: string);
}
declare class CiteprocRsDriverError extends CiteprocRsError {
data: DriverError;
constructor(message: string, data: DriverError);
}
declare class CslStyleError extends CiteprocRsError {
data: StyleError;
constructor(message: string, data: StyleError);
}
}
interface WasmResult<T> {
/** If this is an error, throws the error. */
unwrap(): T;
/** If this is an error, returns it, else throws. */
unwrap_err(): Error;
is_ok(): boolean;
is_err(): boolean;
/** If this is an error, returns the default value. */
unwrap_or(default: T): T;
/** If this is Ok, returns f(ok_val), else returns Err unmodified. */
map<R>(f: (t: T) => R): WasmResult<T>;
/** If this is Ok, returns f(ok_val), else returns the default value. */
map_or<R>(default: R, f: (t: T) => R): R;
}
type CitationFormat = "author-date" | "author" | "numeric" | "label" | "note";
interface LocalizedString {
value: string,
lang?: string,
}
interface ParentLink {
href: string,
lang?: string,
}
interface Link {
href: string,
rel: "self" | "documentation" | "template",
lang?: string,
}
interface Rights {
value: string,
lang?: string,
license?: string,
}
interface StyleInfo {
id: string,
updated: string,
title: LocalizedString,
titleShort?: LocalizedString,
parent?: ParentLink,
links: Link[],
rights?: Rights,
citationFormat?: CitationFormat,
categories: string[],
issn?: string,
eissn?: string,
issnl?: string,
}
interface IndependentMeta {
/** A list of languages for which a locale override was specified.
* Does not include the language-less final override. */
localeOverrides: string[],
hasBibliography: bool,
}
interface StyleMeta {
info: StyleInfo,
features: { [feature: string]: bool },
defaultLocale: string,
/** May be absent on a dependent style */
class?: "in-text" | "note",
cslVersionRequired: string,
/** May be absent on a dependent style */
independentMeta?: IndependentMeta,
};
/**

@@ -132,29 +282,30 @@ */

* * `style` is a CSL style as a string. Independent styles only.
* * `lifecycle` must implement the `Lifecycle` interface
* * `fetcher` must implement the `Fetcher` interface
* * `format` is one of { "html", "rtf" }
*
* Throws an error if it cannot parse the style you gave it.
* @param {string} style
* @param {any} lifecycle
* @param {string} format
* @returns {Driver}
* @param {InitOptions} options
* @returns {WasmResult<Driver>}
*/
static new(style: string, lifecycle: any, format: string): Driver;
static new(options: InitOptions): WasmResult<Driver>;
/**
* Sets the style (which will also cause everything to be recomputed)
* @param {string} style_text
* @param {string} style_text
* @returns {WasmResult<undefined>}
*/
setStyle(style_text: string): void;
setStyle(style_text: string): WasmResult<undefined>;
/**
* Completely overwrites the references library.
* This **will** delete references that are not in the provided list.
* @param {any[]} refs
* @param {any[]} refs
* @returns {WasmResult<undefined>}
*/
resetReferences(refs: any[]): void;
resetReferences(refs: any[]): WasmResult<undefined>;
/**
* Inserts or overwrites references as a batch operation.
* This **will not** delete references that are not in the provided list.
* @param {any[]} refs
* @param {any[]} refs
* @returns {WasmResult<undefined>}
*/
insertReferences(refs: any[]): void;
insertReferences(refs: any[]): WasmResult<undefined>;
/**

@@ -164,11 +315,13 @@ * Inserts or overwrites a reference.

* * `refr` is a Reference object.
* @param {Reference} refr
* @param {Reference} refr
* @returns {WasmResult<undefined>}
*/
insertReference(refr: Reference): void;
insertReference(refr: Reference): WasmResult<undefined>;
/**
* Removes a reference by id. If it is cited, any cites will be dangling. It will also
* disappear from the bibliography.
* @param {string} id
* @param {string} id
* @returns {WasmResult<undefined>}
*/
removeReference(id: string): void;
removeReference(id: string): WasmResult<undefined>;
/**

@@ -178,5 +331,6 @@ * Sets the references to be included in the bibliography despite not being directly cited.

* * `refr` is a
* @param {IncludeUncited} uncited
* @param {IncludeUncited} uncited
* @returns {WasmResult<undefined>}
*/
includeUncited(uncited: IncludeUncited): void;
includeUncited(uncited: IncludeUncited): WasmResult<undefined>;
/**

@@ -186,8 +340,8 @@ * Gets a list of locales in use by the references currently loaded.

* Note that Driver comes pre-loaded with the `en-US` locale.
* @returns {any}
* @returns {WasmResult<string[]>}
*/
toFetch(): any;
toFetch(): WasmResult<string[]>;
/**
* Returns a random cluster id, with an extra guarantee that it isn't already in use.
* @returns {string}
* @returns {string}
*/

@@ -197,10 +351,12 @@ randomClusterId(): string;

* Inserts or replaces a cluster with a matching `id`.
* @param {any} cluster
* @param {Cluster} cluster
* @returns {WasmResult<undefined>}
*/
insertCluster(cluster: any): void;
insertCluster(cluster: Cluster): WasmResult<undefined>;
/**
* Removes a cluster with a matching `id`
* @param {string} cluster_id
* @param {string} cluster_id
* @returns {WasmResult<undefined>}
*/
removeCluster(cluster_id: string): void;
removeCluster(cluster_id: string): WasmResult<undefined>;
/**

@@ -210,5 +366,6 @@ * Resets all the clusters in the processor to a new list.

* * `clusters` is a Cluster[]
* @param {any[]} clusters
* @param {any[]} clusters
* @returns {WasmResult<undefined>}
*/
initClusters(clusters: any[]): void;
initClusters(clusters: any[]): WasmResult<undefined>;
/**

@@ -219,6 +376,6 @@ * Returns the formatted citation cluster for `cluster_id`.

* still useful for initialization.
* @param {string} id
* @returns {any}
* @param {string} id
* @returns {WasmResult<string>}
*/
builtCluster(id: string): any;
builtCluster(id: string): WasmResult<string>;
/**

@@ -232,16 +389,16 @@ * Previews a formatted citation cluster, in a particular position.

* any location you can think of.
* @param {any[]} cites
* @param {any[]} positions
* @param {string} format
* @returns {any}
* @param {any[]} cites
* @param {any[]} positions
* @param {string} format
* @returns {WasmResult<string>}
*/
previewCitationCluster(cites: any[], positions: any[], format: string): any;
previewCitationCluster(cites: any[], positions: any[], format: string): WasmResult<string>;
/**
* @returns {BibEntries}
* @returns {WasmResult<BibEntries>}
*/
makeBibliography(): BibEntries;
makeBibliography(): WasmResult<BibEntries>;
/**
* @returns {BibliographyMeta}
* @returns {WasmResult<BibliographyMeta>}
*/
bibliographyMeta(): BibliographyMeta;
bibliographyMeta(): WasmResult<BibliographyMeta>;
/**

@@ -271,5 +428,6 @@ * Specifies which clusters are actually considered to be in the document, and sets their

* May error without having set_cluster_ids, but with some set_cluster_note_number-s executed.
* @param {any[]} positions
* @param {any[]} positions
* @returns {WasmResult<undefined>}
*/
setClusterOrder(positions: any[]): void;
setClusterOrder(positions: any[]): WasmResult<undefined>;
/**

@@ -283,5 +441,5 @@ * Retrieve any clusters that have been touched since last time `batchedUpdates` was

* * returns an `UpdateSummary`
* @returns {UpdateSummary}
* @returns {WasmResult<UpdateSummary>}
*/
batchedUpdates(): UpdateSummary;
batchedUpdates(): WasmResult<UpdateSummary>;
/**

@@ -291,5 +449,5 @@ * Returns all the clusters and bibliography entries in the document.

* Use this to rehydrate a document or run non-interactively.
* @returns {FullRender}
* @returns {WasmResult<FullRender>}
*/
fullRender(): FullRender;
fullRender(): WasmResult<FullRender>;
/**

@@ -301,6 +459,6 @@ * Drains the `batchedUpdates` queue manually.

* Asynchronously fetches all the locales that may be required, and saves them into the
* engine. Uses your provided `Lifecycle.fetchLocale` function.
* @returns {Promise<any>}
* engine. Uses your provided `Fetcher.fetchLocale` function.
* @returns {Promise<any>}
*/
fetchAll(): Promise<any>;
fetchLocales(): Promise<any>;
}
let imports = {};
imports['__wbindgen_placeholder__'] = module.exports;
let wasm;
const { TextDecoder } = require(String.raw`util`);
const { WasmResult, CiteprocRsError, CiteprocRsDriverError, CslStyleError } = require(String.raw`./snippets/wasm-1883a0b9dcad429e/src/js/include.js`);
const { TextEncoder, TextDecoder } = require(String.raw`util`);

@@ -28,16 +29,60 @@ const heap = new Array(32).fill(undefined);

let cachegetNodeBufferMemory0 = null;
function getNodeBufferMemory0() {
if (cachegetNodeBufferMemory0 === null || cachegetNodeBufferMemory0.buffer !== wasm.memory.buffer) {
cachegetNodeBufferMemory0 = Buffer.from(wasm.memory.buffer);
let cachegetUint8Memory0 = null;
function getUint8Memory0() {
if (cachegetUint8Memory0 === null || cachegetUint8Memory0.buffer !== wasm.memory.buffer) {
cachegetUint8Memory0 = new Uint8Array(wasm.memory.buffer);
}
return cachegetNodeBufferMemory0;
return cachegetUint8Memory0;
}
function passStringToWasm0(arg, malloc) {
let cachedTextEncoder = new TextEncoder('utf-8');
const len = Buffer.byteLength(arg);
const ptr = malloc(len);
getNodeBufferMemory0().write(arg, ptr, len);
WASM_VECTOR_LEN = len;
const encodeString = (typeof cachedTextEncoder.encodeInto === 'function'
? function (arg, view) {
return cachedTextEncoder.encodeInto(arg, view);
}
: function (arg, view) {
const buf = cachedTextEncoder.encode(arg);
view.set(buf);
return {
read: arg.length,
written: buf.length
};
});
function passStringToWasm0(arg, malloc, realloc) {
if (realloc === undefined) {
const buf = cachedTextEncoder.encode(arg);
const ptr = malloc(buf.length);
getUint8Memory0().subarray(ptr, ptr + buf.length).set(buf);
WASM_VECTOR_LEN = buf.length;
return ptr;
}
let len = arg.length;
let ptr = malloc(len);
const mem = getUint8Memory0();
let offset = 0;
for (; offset < len; offset++) {
const code = arg.charCodeAt(offset);
if (code > 0x7F) break;
mem[ptr + offset] = code;
}
if (offset !== len) {
if (offset !== 0) {
arg = arg.slice(offset);
}
ptr = realloc(ptr, len, len = offset + arg.length * 3);
const view = getUint8Memory0().subarray(ptr + offset, ptr + len);
const ret = encodeString(arg, view);
offset += ret.written;
}
WASM_VECTOR_LEN = offset;
return ptr;

@@ -58,10 +103,2 @@ }

let cachegetUint8Memory0 = null;
function getUint8Memory0() {
if (cachegetUint8Memory0 === null || cachegetUint8Memory0.buffer !== wasm.memory.buffer) {
cachegetUint8Memory0 = new Uint8Array(wasm.memory.buffer);
}
return cachegetUint8Memory0;
}
function getStringFromWasm0(ptr, len) {

@@ -85,3 +122,3 @@ return cachedTextDecoder.decode(getUint8Memory0().subarray(ptr, ptr + len));

function makeMutClosure(arg0, arg1, dtor, f) {
const state = { a: arg0, b: arg1, cnt: 1 };
const state = { a: arg0, b: arg1, cnt: 1, dtor };
const real = (...args) => {

@@ -97,13 +134,30 @@ // First up with a closure we increment the internal reference

} finally {
if (--state.cnt === 0) wasm.__wbindgen_export_2.get(dtor)(a, state.b);
else state.a = a;
if (--state.cnt === 0) {
wasm.__wbindgen_export_2.get(state.dtor)(a, state.b);
} else {
state.a = a;
}
}
};
real.original = state;
return real;
}
function __wbg_adapter_20(arg0, arg1, arg2) {
wasm._dyn_core__ops__function__FnMut__A____Output___R_as_wasm_bindgen__closure__WasmClosure___describe__invoke__hc76d7ca4c06d1374(arg0, arg1, addHeapObject(arg2));
function __wbg_adapter_24(arg0, arg1, arg2) {
wasm._dyn_core__ops__function__FnMut__A____Output___R_as_wasm_bindgen__closure__WasmClosure___describe__invoke__h2b1b33880a98c55e(arg0, arg1, addHeapObject(arg2));
}
/**
* Parses a CSL style, either independent or dependent, and returns its metadata.
* @param {string} style
* @returns {WasmResult<StyleMeta>}
*/
module.exports.parseStyleMetadata = function(style) {
var ptr0 = passStringToWasm0(style, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
var len0 = WASM_VECTOR_LEN;
var ret = wasm.parseStyleMetadata(ptr0, len0);
return takeObject(ret);
};
let cachegetUint32Memory0 = null;

@@ -137,4 +191,4 @@ function getUint32Memory0() {

}
function __wbg_adapter_66(arg0, arg1, arg2, arg3) {
wasm.wasm_bindgen__convert__closures__invoke2_mut__h982cd7b8d71edcca(arg0, arg1, addHeapObject(arg2), addHeapObject(arg3));
function __wbg_adapter_81(arg0, arg1, arg2, arg3) {
wasm.wasm_bindgen__convert__closures__invoke2_mut__h4915090d68cfd6bd(arg0, arg1, addHeapObject(arg2), addHeapObject(arg3));
}

@@ -156,6 +210,11 @@

free() {
__destroy_into_raw() {
const ptr = this.ptr;
this.ptr = 0;
return ptr;
}
free() {
const ptr = this.__destroy_into_raw();
wasm.__wbg_driver_free(ptr);

@@ -167,18 +226,12 @@ }

* * `style` is a CSL style as a string. Independent styles only.
* * `lifecycle` must implement the `Lifecycle` interface
* * `fetcher` must implement the `Fetcher` interface
* * `format` is one of { "html", "rtf" }
*
* Throws an error if it cannot parse the style you gave it.
* @param {string} style
* @param {any} lifecycle
* @param {string} format
* @returns {Driver}
* @param {InitOptions} options
* @returns {WasmResult<Driver>}
*/
static new(style, lifecycle, format) {
var ptr0 = passStringToWasm0(style, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
var len0 = WASM_VECTOR_LEN;
var ptr1 = passStringToWasm0(format, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
var len1 = WASM_VECTOR_LEN;
var ret = wasm.driver_new(ptr0, len0, addHeapObject(lifecycle), ptr1, len1);
return Driver.__wrap(ret);
static new(options) {
var ret = wasm.driver_new(addHeapObject(options));
return takeObject(ret);
}

@@ -188,2 +241,3 @@ /**

* @param {string} style_text
* @returns {WasmResult<undefined>}
*/

@@ -193,3 +247,4 @@ setStyle(style_text) {

var len0 = WASM_VECTOR_LEN;
wasm.driver_setStyle(this.ptr, ptr0, len0);
var ret = wasm.driver_setStyle(this.ptr, ptr0, len0);
return takeObject(ret);
}

@@ -200,2 +255,3 @@ /**

* @param {any[]} refs
* @returns {WasmResult<undefined>}
*/

@@ -205,3 +261,4 @@ resetReferences(refs) {

var len0 = WASM_VECTOR_LEN;
wasm.driver_resetReferences(this.ptr, ptr0, len0);
var ret = wasm.driver_resetReferences(this.ptr, ptr0, len0);
return takeObject(ret);
}

@@ -212,2 +269,3 @@ /**

* @param {any[]} refs
* @returns {WasmResult<undefined>}
*/

@@ -217,3 +275,4 @@ insertReferences(refs) {

var len0 = WASM_VECTOR_LEN;
wasm.driver_insertReferences(this.ptr, ptr0, len0);
var ret = wasm.driver_insertReferences(this.ptr, ptr0, len0);
return takeObject(ret);
}

@@ -225,5 +284,7 @@ /**

* @param {Reference} refr
* @returns {WasmResult<undefined>}
*/
insertReference(refr) {
wasm.driver_insertReference(this.ptr, addHeapObject(refr));
var ret = wasm.driver_insertReference(this.ptr, addHeapObject(refr));
return takeObject(ret);
}

@@ -234,2 +295,3 @@ /**

* @param {string} id
* @returns {WasmResult<undefined>}
*/

@@ -239,3 +301,4 @@ removeReference(id) {

var len0 = WASM_VECTOR_LEN;
wasm.driver_removeReference(this.ptr, ptr0, len0);
var ret = wasm.driver_removeReference(this.ptr, ptr0, len0);
return takeObject(ret);
}

@@ -247,5 +310,7 @@ /**

* @param {IncludeUncited} uncited
* @returns {WasmResult<undefined>}
*/
includeUncited(uncited) {
wasm.driver_includeUncited(this.ptr, addHeapObject(uncited));
var ret = wasm.driver_includeUncited(this.ptr, addHeapObject(uncited));
return takeObject(ret);
}

@@ -256,3 +321,3 @@ /**

* Note that Driver comes pre-loaded with the `en-US` locale.
* @returns {any}
* @returns {WasmResult<string[]>}
*/

@@ -269,7 +334,9 @@ toFetch() {

try {
wasm.driver_randomClusterId(8, this.ptr);
var r0 = getInt32Memory0()[8 / 4 + 0];
var r1 = getInt32Memory0()[8 / 4 + 1];
const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);
wasm.driver_randomClusterId(retptr, this.ptr);
var r0 = getInt32Memory0()[retptr / 4 + 0];
var r1 = getInt32Memory0()[retptr / 4 + 1];
return getStringFromWasm0(r0, r1);
} finally {
wasm.__wbindgen_add_to_stack_pointer(16);
wasm.__wbindgen_free(r0, r1);

@@ -280,6 +347,8 @@ }

* Inserts or replaces a cluster with a matching `id`.
* @param {any} cluster
* @param {Cluster} cluster
* @returns {WasmResult<undefined>}
*/
insertCluster(cluster) {
wasm.driver_insertCluster(this.ptr, addHeapObject(cluster));
var ret = wasm.driver_insertCluster(this.ptr, addHeapObject(cluster));
return takeObject(ret);
}

@@ -289,2 +358,3 @@ /**

* @param {string} cluster_id
* @returns {WasmResult<undefined>}
*/

@@ -294,3 +364,4 @@ removeCluster(cluster_id) {

var len0 = WASM_VECTOR_LEN;
wasm.driver_removeCluster(this.ptr, ptr0, len0);
var ret = wasm.driver_removeCluster(this.ptr, ptr0, len0);
return takeObject(ret);
}

@@ -302,2 +373,3 @@ /**

* @param {any[]} clusters
* @returns {WasmResult<undefined>}
*/

@@ -307,3 +379,4 @@ initClusters(clusters) {

var len0 = WASM_VECTOR_LEN;
wasm.driver_initClusters(this.ptr, ptr0, len0);
var ret = wasm.driver_initClusters(this.ptr, ptr0, len0);
return takeObject(ret);
}

@@ -316,3 +389,3 @@ /**

* @param {string} id
* @returns {any}
* @returns {WasmResult<string>}
*/

@@ -336,3 +409,3 @@ builtCluster(id) {

* @param {string} format
* @returns {any}
* @returns {WasmResult<string>}
*/

@@ -350,3 +423,3 @@ previewCitationCluster(cites, positions, format) {

/**
* @returns {BibEntries}
* @returns {WasmResult<BibEntries>}
*/

@@ -358,3 +431,3 @@ makeBibliography() {

/**
* @returns {BibliographyMeta}
* @returns {WasmResult<BibliographyMeta>}
*/

@@ -390,2 +463,3 @@ bibliographyMeta() {

* @param {any[]} positions
* @returns {WasmResult<undefined>}
*/

@@ -395,3 +469,4 @@ setClusterOrder(positions) {

var len0 = WASM_VECTOR_LEN;
wasm.driver_setClusterOrder(this.ptr, ptr0, len0);
var ret = wasm.driver_setClusterOrder(this.ptr, ptr0, len0);
return takeObject(ret);
}

@@ -406,3 +481,3 @@ /**

* * returns an `UpdateSummary`
* @returns {UpdateSummary}
* @returns {WasmResult<UpdateSummary>}
*/

@@ -417,3 +492,3 @@ batchedUpdates() {

* Use this to rehydrate a document or run non-interactively.
* @returns {FullRender}
* @returns {WasmResult<FullRender>}
*/

@@ -432,7 +507,7 @@ fullRender() {

* Asynchronously fetches all the locales that may be required, and saves them into the
* engine. Uses your provided `Lifecycle.fetchLocale` function.
* engine. Uses your provided `Fetcher.fetchLocale` function.
* @returns {Promise<any>}
*/
fetchAll() {
var ret = wasm.driver_fetchAll(this.ptr);
fetchLocales() {
var ret = wasm.driver_fetchLocales(this.ptr);
return takeObject(ret);

@@ -451,2 +526,22 @@ }

module.exports.__wbg_debug_4885c3f7d6f044a3 = function(arg0, arg1) {
console.debug(getStringFromWasm0(arg0, arg1));
};
module.exports.__wbg_log_bee3ea1a89f334d8 = function(arg0, arg1) {
console.log(getStringFromWasm0(arg0, arg1));
};
module.exports.__wbg_info_0547ff9513f2019b = function(arg0, arg1) {
console.info(getStringFromWasm0(arg0, arg1));
};
module.exports.__wbg_warn_a478dea6e6e05394 = function(arg0, arg1) {
console.warn(getStringFromWasm0(arg0, arg1));
};
module.exports.__wbg_error_72e88ba6901b6eee = function(arg0, arg1) {
console.error(getStringFromWasm0(arg0, arg1));
};
module.exports.__wbindgen_json_serialize = function(arg0, arg1) {

@@ -461,17 +556,7 @@ const obj = getObject(arg1);

module.exports.__wbindgen_json_parse = function(arg0, arg1) {
var ret = JSON.parse(getStringFromWasm0(arg0, arg1));
module.exports.__wbindgen_string_new = function(arg0, arg1) {
var ret = getStringFromWasm0(arg0, arg1);
return addHeapObject(ret);
};
module.exports.__wbg_fetchLocale_8f52b973b0739a6c = function(arg0, arg1, arg2) {
var ret = getObject(arg0).fetchLocale(getStringFromWasm0(arg1, arg2));
return addHeapObject(ret);
};
module.exports.__wbindgen_object_clone_ref = function(arg0) {
var ret = getObject(arg0);
return addHeapObject(ret);
};
module.exports.__wbindgen_cb_drop = function(arg0) {

@@ -487,22 +572,63 @@ const obj = takeObject(arg0).original;

module.exports.__wbg_debug_4885c3f7d6f044a3 = function(arg0, arg1) {
console.debug(getStringFromWasm0(arg0, arg1));
module.exports.__wbindgen_json_parse = function(arg0, arg1) {
var ret = JSON.parse(getStringFromWasm0(arg0, arg1));
return addHeapObject(ret);
};
module.exports.__wbg_log_bee3ea1a89f334d8 = function(arg0, arg1) {
console.log(getStringFromWasm0(arg0, arg1));
module.exports.__wbg_driver_new = function(arg0) {
var ret = Driver.__wrap(arg0);
return addHeapObject(ret);
};
module.exports.__wbg_info_0547ff9513f2019b = function(arg0, arg1) {
console.info(getStringFromWasm0(arg0, arg1));
module.exports.__wbg_new_f12987d5c30f0ab7 = function(arg0) {
var ret = new CiteprocRsError(takeObject(arg0));
return addHeapObject(ret);
};
module.exports.__wbg_warn_a478dea6e6e05394 = function(arg0, arg1) {
console.warn(getStringFromWasm0(arg0, arg1));
module.exports.__wbg_new_c5e56e6577bc2b6a = function(arg0, arg1) {
var ret = new CslStyleError(takeObject(arg0), takeObject(arg1));
return addHeapObject(ret);
};
module.exports.__wbg_error_72e88ba6901b6eee = function(arg0, arg1) {
console.error(getStringFromWasm0(arg0, arg1));
module.exports.__wbg_new_6edca5ab9ee61764 = function(arg0) {
var ret = new WasmResult(takeObject(arg0));
return addHeapObject(ret);
};
module.exports.__wbg_get_1edc26456ed84f9b = function(arg0, arg1) {
var ret = getObject(arg0)[takeObject(arg1)];
return addHeapObject(ret);
};
module.exports.__wbg_new_8d5f3cd64eaaa8b5 = function(arg0, arg1) {
var ret = new CiteprocRsDriverError(takeObject(arg0), takeObject(arg1));
return addHeapObject(ret);
};
module.exports.__wbindgen_object_clone_ref = function(arg0) {
var ret = getObject(arg0);
return addHeapObject(ret);
};
module.exports.__wbindgen_is_undefined = function(arg0) {
var ret = getObject(arg0) === undefined;
return ret;
};
module.exports.__wbindgen_is_object = function(arg0) {
const val = getObject(arg0);
var ret = typeof(val) === 'object' && val !== null;
return ret;
};
module.exports.__wbindgen_is_function = function(arg0) {
var ret = typeof(getObject(arg0)) === 'function';
return ret;
};
module.exports.__wbg_fetchLocale_d644d4ae2ca50f81 = function(arg0, arg1, arg2) {
var ret = getObject(arg0).fetchLocale(getStringFromWasm0(arg1, arg2));
return addHeapObject(ret);
};
module.exports.__wbg_new_59cb74e423758ede = function() {

@@ -529,8 +655,3 @@ var ret = new Error();

module.exports.__wbg_new_1d56e97b8de3067f = function(arg0, arg1) {
var ret = new Error(getStringFromWasm0(arg0, arg1));
return addHeapObject(ret);
};
module.exports.__wbg_call_0246f1c8ff252fb6 = handleError(function(arg0, arg1, arg2) {
module.exports.__wbg_call_f5e0576f61ee7461 = handleError(function(arg0, arg1, arg2) {
var ret = getObject(arg0).call(getObject(arg1), getObject(arg2));

@@ -540,3 +661,3 @@ return addHeapObject(ret);

module.exports.__wbg_new_09f2ad087112acf0 = function(arg0, arg1) {
module.exports.__wbg_new_3ea8490cd276c848 = function(arg0, arg1) {
try {

@@ -548,3 +669,3 @@ var state0 = {a: arg0, b: arg1};

try {
return __wbg_adapter_66(a, state0.b, arg0, arg1);
return __wbg_adapter_81(a, state0.b, arg0, arg1);
} finally {

@@ -561,3 +682,3 @@ state0.a = a;

module.exports.__wbg_resolve_708df7651c8929b8 = function(arg0) {
module.exports.__wbg_resolve_778af3f90b8e2b59 = function(arg0) {
var ret = Promise.resolve(getObject(arg0));

@@ -567,3 +688,3 @@ return addHeapObject(ret);

module.exports.__wbg_then_8c23dce80c84c8fb = function(arg0, arg1) {
module.exports.__wbg_then_367b3e718069cfb9 = function(arg0, arg1) {
var ret = getObject(arg0).then(getObject(arg1));

@@ -573,3 +694,3 @@ return addHeapObject(ret);

module.exports.__wbg_then_300153bb889a5b4b = function(arg0, arg1, arg2) {
module.exports.__wbg_then_ac66ca61394bfd21 = function(arg0, arg1, arg2) {
var ret = getObject(arg0).then(getObject(arg1), getObject(arg2));

@@ -579,15 +700,2 @@ return addHeapObject(ret);

module.exports.__wbindgen_is_undefined = function(arg0) {
var ret = getObject(arg0) === undefined;
return ret;
};
module.exports.__wbg_getRandomValues_3ac1b33c90b52596 = function(arg0, arg1, arg2) {
getObject(arg0).getRandomValues(getArrayU8FromWasm0(arg1, arg2));
};
module.exports.__wbg_randomFillSync_6f956029658662ec = function(arg0, arg1, arg2) {
getObject(arg0).randomFillSync(getArrayU8FromWasm0(arg1, arg2));
};
module.exports.__wbg_self_1c83eb4471d9eb9b = handleError(function() {

@@ -623,2 +731,10 @@ var ret = self.self;

module.exports.__wbg_getRandomValues_3ac1b33c90b52596 = function(arg0, arg1, arg2) {
getObject(arg0).getRandomValues(getArrayU8FromWasm0(arg1, arg2));
};
module.exports.__wbg_randomFillSync_6f956029658662ec = function(arg0, arg1, arg2) {
getObject(arg0).randomFillSync(getArrayU8FromWasm0(arg1, arg2));
};
module.exports.__wbindgen_string_get = function(arg0, arg1) {

@@ -637,8 +753,4 @@ const obj = getObject(arg1);

module.exports.__wbindgen_rethrow = function(arg0) {
throw takeObject(arg0);
};
module.exports.__wbindgen_closure_wrapper855 = function(arg0, arg1, arg2) {
var ret = makeMutClosure(arg0, arg1, 186, __wbg_adapter_20);
module.exports.__wbindgen_closure_wrapper952 = function(arg0, arg1, arg2) {
var ret = makeMutClosure(arg0, arg1, 227, __wbg_adapter_24);
return addHeapObject(ret);

@@ -645,0 +757,0 @@ };

@@ -0,1 +1,2 @@

import { WasmResult, CiteprocRsError, CiteprocRsDriverError, CslStyleError } from './snippets/wasm-1883a0b9dcad429e/src/js/include.js';
import * as wasm from './citeproc_rs_wasm_bg.wasm';

@@ -120,3 +121,3 @@

function makeMutClosure(arg0, arg1, dtor, f) {
const state = { a: arg0, b: arg1, cnt: 1 };
const state = { a: arg0, b: arg1, cnt: 1, dtor };
const real = (...args) => {

@@ -132,13 +133,30 @@ // First up with a closure we increment the internal reference

} finally {
if (--state.cnt === 0) wasm.__wbindgen_export_2.get(dtor)(a, state.b);
else state.a = a;
if (--state.cnt === 0) {
wasm.__wbindgen_export_2.get(state.dtor)(a, state.b);
} else {
state.a = a;
}
}
};
real.original = state;
return real;
}
function __wbg_adapter_20(arg0, arg1, arg2) {
wasm._dyn_core__ops__function__FnMut__A____Output___R_as_wasm_bindgen__closure__WasmClosure___describe__invoke__hc76d7ca4c06d1374(arg0, arg1, addHeapObject(arg2));
function __wbg_adapter_24(arg0, arg1, arg2) {
wasm._dyn_core__ops__function__FnMut__A____Output___R_as_wasm_bindgen__closure__WasmClosure___describe__invoke__h2b1b33880a98c55e(arg0, arg1, addHeapObject(arg2));
}
/**
* Parses a CSL style, either independent or dependent, and returns its metadata.
* @param {string} style
* @returns {WasmResult<StyleMeta>}
*/
export function parseStyleMetadata(style) {
var ptr0 = passStringToWasm0(style, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
var len0 = WASM_VECTOR_LEN;
var ret = wasm.parseStyleMetadata(ptr0, len0);
return takeObject(ret);
}
let cachegetUint32Memory0 = null;

@@ -172,4 +190,4 @@ function getUint32Memory0() {

}
function __wbg_adapter_66(arg0, arg1, arg2, arg3) {
wasm.wasm_bindgen__convert__closures__invoke2_mut__h982cd7b8d71edcca(arg0, arg1, addHeapObject(arg2), addHeapObject(arg3));
function __wbg_adapter_81(arg0, arg1, arg2, arg3) {
wasm.wasm_bindgen__convert__closures__invoke2_mut__h4915090d68cfd6bd(arg0, arg1, addHeapObject(arg2), addHeapObject(arg3));
}

@@ -191,6 +209,11 @@

free() {
__destroy_into_raw() {
const ptr = this.ptr;
this.ptr = 0;
return ptr;
}
free() {
const ptr = this.__destroy_into_raw();
wasm.__wbg_driver_free(ptr);

@@ -202,18 +225,12 @@ }

* * `style` is a CSL style as a string. Independent styles only.
* * `lifecycle` must implement the `Lifecycle` interface
* * `fetcher` must implement the `Fetcher` interface
* * `format` is one of { "html", "rtf" }
*
* Throws an error if it cannot parse the style you gave it.
* @param {string} style
* @param {any} lifecycle
* @param {string} format
* @returns {Driver}
* @param {InitOptions} options
* @returns {WasmResult<Driver>}
*/
static new(style, lifecycle, format) {
var ptr0 = passStringToWasm0(style, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
var len0 = WASM_VECTOR_LEN;
var ptr1 = passStringToWasm0(format, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
var len1 = WASM_VECTOR_LEN;
var ret = wasm.driver_new(ptr0, len0, addHeapObject(lifecycle), ptr1, len1);
return Driver.__wrap(ret);
static new(options) {
var ret = wasm.driver_new(addHeapObject(options));
return takeObject(ret);
}

@@ -223,2 +240,3 @@ /**

* @param {string} style_text
* @returns {WasmResult<undefined>}
*/

@@ -228,3 +246,4 @@ setStyle(style_text) {

var len0 = WASM_VECTOR_LEN;
wasm.driver_setStyle(this.ptr, ptr0, len0);
var ret = wasm.driver_setStyle(this.ptr, ptr0, len0);
return takeObject(ret);
}

@@ -235,2 +254,3 @@ /**

* @param {any[]} refs
* @returns {WasmResult<undefined>}
*/

@@ -240,3 +260,4 @@ resetReferences(refs) {

var len0 = WASM_VECTOR_LEN;
wasm.driver_resetReferences(this.ptr, ptr0, len0);
var ret = wasm.driver_resetReferences(this.ptr, ptr0, len0);
return takeObject(ret);
}

@@ -247,2 +268,3 @@ /**

* @param {any[]} refs
* @returns {WasmResult<undefined>}
*/

@@ -252,3 +274,4 @@ insertReferences(refs) {

var len0 = WASM_VECTOR_LEN;
wasm.driver_insertReferences(this.ptr, ptr0, len0);
var ret = wasm.driver_insertReferences(this.ptr, ptr0, len0);
return takeObject(ret);
}

@@ -260,5 +283,7 @@ /**

* @param {Reference} refr
* @returns {WasmResult<undefined>}
*/
insertReference(refr) {
wasm.driver_insertReference(this.ptr, addHeapObject(refr));
var ret = wasm.driver_insertReference(this.ptr, addHeapObject(refr));
return takeObject(ret);
}

@@ -269,2 +294,3 @@ /**

* @param {string} id
* @returns {WasmResult<undefined>}
*/

@@ -274,3 +300,4 @@ removeReference(id) {

var len0 = WASM_VECTOR_LEN;
wasm.driver_removeReference(this.ptr, ptr0, len0);
var ret = wasm.driver_removeReference(this.ptr, ptr0, len0);
return takeObject(ret);
}

@@ -282,5 +309,7 @@ /**

* @param {IncludeUncited} uncited
* @returns {WasmResult<undefined>}
*/
includeUncited(uncited) {
wasm.driver_includeUncited(this.ptr, addHeapObject(uncited));
var ret = wasm.driver_includeUncited(this.ptr, addHeapObject(uncited));
return takeObject(ret);
}

@@ -291,3 +320,3 @@ /**

* Note that Driver comes pre-loaded with the `en-US` locale.
* @returns {any}
* @returns {WasmResult<string[]>}
*/

@@ -304,7 +333,9 @@ toFetch() {

try {
wasm.driver_randomClusterId(8, this.ptr);
var r0 = getInt32Memory0()[8 / 4 + 0];
var r1 = getInt32Memory0()[8 / 4 + 1];
const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);
wasm.driver_randomClusterId(retptr, this.ptr);
var r0 = getInt32Memory0()[retptr / 4 + 0];
var r1 = getInt32Memory0()[retptr / 4 + 1];
return getStringFromWasm0(r0, r1);
} finally {
wasm.__wbindgen_add_to_stack_pointer(16);
wasm.__wbindgen_free(r0, r1);

@@ -315,6 +346,8 @@ }

* Inserts or replaces a cluster with a matching `id`.
* @param {any} cluster
* @param {Cluster} cluster
* @returns {WasmResult<undefined>}
*/
insertCluster(cluster) {
wasm.driver_insertCluster(this.ptr, addHeapObject(cluster));
var ret = wasm.driver_insertCluster(this.ptr, addHeapObject(cluster));
return takeObject(ret);
}

@@ -324,2 +357,3 @@ /**

* @param {string} cluster_id
* @returns {WasmResult<undefined>}
*/

@@ -329,3 +363,4 @@ removeCluster(cluster_id) {

var len0 = WASM_VECTOR_LEN;
wasm.driver_removeCluster(this.ptr, ptr0, len0);
var ret = wasm.driver_removeCluster(this.ptr, ptr0, len0);
return takeObject(ret);
}

@@ -337,2 +372,3 @@ /**

* @param {any[]} clusters
* @returns {WasmResult<undefined>}
*/

@@ -342,3 +378,4 @@ initClusters(clusters) {

var len0 = WASM_VECTOR_LEN;
wasm.driver_initClusters(this.ptr, ptr0, len0);
var ret = wasm.driver_initClusters(this.ptr, ptr0, len0);
return takeObject(ret);
}

@@ -351,3 +388,3 @@ /**

* @param {string} id
* @returns {any}
* @returns {WasmResult<string>}
*/

@@ -371,3 +408,3 @@ builtCluster(id) {

* @param {string} format
* @returns {any}
* @returns {WasmResult<string>}
*/

@@ -385,3 +422,3 @@ previewCitationCluster(cites, positions, format) {

/**
* @returns {BibEntries}
* @returns {WasmResult<BibEntries>}
*/

@@ -393,3 +430,3 @@ makeBibliography() {

/**
* @returns {BibliographyMeta}
* @returns {WasmResult<BibliographyMeta>}
*/

@@ -425,2 +462,3 @@ bibliographyMeta() {

* @param {any[]} positions
* @returns {WasmResult<undefined>}
*/

@@ -430,3 +468,4 @@ setClusterOrder(positions) {

var len0 = WASM_VECTOR_LEN;
wasm.driver_setClusterOrder(this.ptr, ptr0, len0);
var ret = wasm.driver_setClusterOrder(this.ptr, ptr0, len0);
return takeObject(ret);
}

@@ -441,3 +480,3 @@ /**

* * returns an `UpdateSummary`
* @returns {UpdateSummary}
* @returns {WasmResult<UpdateSummary>}
*/

@@ -452,3 +491,3 @@ batchedUpdates() {

* Use this to rehydrate a document or run non-interactively.
* @returns {FullRender}
* @returns {WasmResult<FullRender>}
*/

@@ -467,7 +506,7 @@ fullRender() {

* Asynchronously fetches all the locales that may be required, and saves them into the
* engine. Uses your provided `Lifecycle.fetchLocale` function.
* engine. Uses your provided `Fetcher.fetchLocale` function.
* @returns {Promise<any>}
*/
fetchAll() {
var ret = wasm.driver_fetchAll(this.ptr);
fetchLocales() {
var ret = wasm.driver_fetchLocales(this.ptr);
return takeObject(ret);

@@ -485,2 +524,22 @@ }

export const __wbg_debug_4885c3f7d6f044a3 = function(arg0, arg1) {
console.debug(getStringFromWasm0(arg0, arg1));
};
export const __wbg_log_bee3ea1a89f334d8 = function(arg0, arg1) {
console.log(getStringFromWasm0(arg0, arg1));
};
export const __wbg_info_0547ff9513f2019b = function(arg0, arg1) {
console.info(getStringFromWasm0(arg0, arg1));
};
export const __wbg_warn_a478dea6e6e05394 = function(arg0, arg1) {
console.warn(getStringFromWasm0(arg0, arg1));
};
export const __wbg_error_72e88ba6901b6eee = function(arg0, arg1) {
console.error(getStringFromWasm0(arg0, arg1));
};
export const __wbindgen_json_serialize = function(arg0, arg1) {

@@ -495,17 +554,7 @@ const obj = getObject(arg1);

export const __wbindgen_json_parse = function(arg0, arg1) {
var ret = JSON.parse(getStringFromWasm0(arg0, arg1));
export const __wbindgen_string_new = function(arg0, arg1) {
var ret = getStringFromWasm0(arg0, arg1);
return addHeapObject(ret);
};
export const __wbg_fetchLocale_8f52b973b0739a6c = function(arg0, arg1, arg2) {
var ret = getObject(arg0).fetchLocale(getStringFromWasm0(arg1, arg2));
return addHeapObject(ret);
};
export const __wbindgen_object_clone_ref = function(arg0) {
var ret = getObject(arg0);
return addHeapObject(ret);
};
export const __wbindgen_cb_drop = function(arg0) {

@@ -521,22 +570,63 @@ const obj = takeObject(arg0).original;

export const __wbg_debug_4885c3f7d6f044a3 = function(arg0, arg1) {
console.debug(getStringFromWasm0(arg0, arg1));
export const __wbindgen_json_parse = function(arg0, arg1) {
var ret = JSON.parse(getStringFromWasm0(arg0, arg1));
return addHeapObject(ret);
};
export const __wbg_log_bee3ea1a89f334d8 = function(arg0, arg1) {
console.log(getStringFromWasm0(arg0, arg1));
export const __wbg_driver_new = function(arg0) {
var ret = Driver.__wrap(arg0);
return addHeapObject(ret);
};
export const __wbg_info_0547ff9513f2019b = function(arg0, arg1) {
console.info(getStringFromWasm0(arg0, arg1));
export const __wbg_new_f12987d5c30f0ab7 = function(arg0) {
var ret = new CiteprocRsError(takeObject(arg0));
return addHeapObject(ret);
};
export const __wbg_warn_a478dea6e6e05394 = function(arg0, arg1) {
console.warn(getStringFromWasm0(arg0, arg1));
export const __wbg_new_c5e56e6577bc2b6a = function(arg0, arg1) {
var ret = new CslStyleError(takeObject(arg0), takeObject(arg1));
return addHeapObject(ret);
};
export const __wbg_error_72e88ba6901b6eee = function(arg0, arg1) {
console.error(getStringFromWasm0(arg0, arg1));
export const __wbg_new_6edca5ab9ee61764 = function(arg0) {
var ret = new WasmResult(takeObject(arg0));
return addHeapObject(ret);
};
export const __wbg_get_1edc26456ed84f9b = function(arg0, arg1) {
var ret = getObject(arg0)[takeObject(arg1)];
return addHeapObject(ret);
};
export const __wbg_new_8d5f3cd64eaaa8b5 = function(arg0, arg1) {
var ret = new CiteprocRsDriverError(takeObject(arg0), takeObject(arg1));
return addHeapObject(ret);
};
export const __wbindgen_object_clone_ref = function(arg0) {
var ret = getObject(arg0);
return addHeapObject(ret);
};
export const __wbindgen_is_undefined = function(arg0) {
var ret = getObject(arg0) === undefined;
return ret;
};
export const __wbindgen_is_object = function(arg0) {
const val = getObject(arg0);
var ret = typeof(val) === 'object' && val !== null;
return ret;
};
export const __wbindgen_is_function = function(arg0) {
var ret = typeof(getObject(arg0)) === 'function';
return ret;
};
export const __wbg_fetchLocale_d644d4ae2ca50f81 = function(arg0, arg1, arg2) {
var ret = getObject(arg0).fetchLocale(getStringFromWasm0(arg1, arg2));
return addHeapObject(ret);
};
export const __wbg_new_59cb74e423758ede = function() {

@@ -563,8 +653,3 @@ var ret = new Error();

export const __wbg_new_1d56e97b8de3067f = function(arg0, arg1) {
var ret = new Error(getStringFromWasm0(arg0, arg1));
return addHeapObject(ret);
};
export const __wbg_call_0246f1c8ff252fb6 = handleError(function(arg0, arg1, arg2) {
export const __wbg_call_f5e0576f61ee7461 = handleError(function(arg0, arg1, arg2) {
var ret = getObject(arg0).call(getObject(arg1), getObject(arg2));

@@ -574,3 +659,3 @@ return addHeapObject(ret);

export const __wbg_new_09f2ad087112acf0 = function(arg0, arg1) {
export const __wbg_new_3ea8490cd276c848 = function(arg0, arg1) {
try {

@@ -582,3 +667,3 @@ var state0 = {a: arg0, b: arg1};

try {
return __wbg_adapter_66(a, state0.b, arg0, arg1);
return __wbg_adapter_81(a, state0.b, arg0, arg1);
} finally {

@@ -595,3 +680,3 @@ state0.a = a;

export const __wbg_resolve_708df7651c8929b8 = function(arg0) {
export const __wbg_resolve_778af3f90b8e2b59 = function(arg0) {
var ret = Promise.resolve(getObject(arg0));

@@ -601,3 +686,3 @@ return addHeapObject(ret);

export const __wbg_then_8c23dce80c84c8fb = function(arg0, arg1) {
export const __wbg_then_367b3e718069cfb9 = function(arg0, arg1) {
var ret = getObject(arg0).then(getObject(arg1));

@@ -607,3 +692,3 @@ return addHeapObject(ret);

export const __wbg_then_300153bb889a5b4b = function(arg0, arg1, arg2) {
export const __wbg_then_ac66ca61394bfd21 = function(arg0, arg1, arg2) {
var ret = getObject(arg0).then(getObject(arg1), getObject(arg2));

@@ -613,15 +698,2 @@ return addHeapObject(ret);

export const __wbindgen_is_undefined = function(arg0) {
var ret = getObject(arg0) === undefined;
return ret;
};
export const __wbg_getRandomValues_3ac1b33c90b52596 = function(arg0, arg1, arg2) {
getObject(arg0).getRandomValues(getArrayU8FromWasm0(arg1, arg2));
};
export const __wbg_randomFillSync_6f956029658662ec = function(arg0, arg1, arg2) {
getObject(arg0).randomFillSync(getArrayU8FromWasm0(arg1, arg2));
};
export const __wbg_self_1c83eb4471d9eb9b = handleError(function() {

@@ -657,2 +729,10 @@ var ret = self.self;

export const __wbg_getRandomValues_3ac1b33c90b52596 = function(arg0, arg1, arg2) {
getObject(arg0).getRandomValues(getArrayU8FromWasm0(arg1, arg2));
};
export const __wbg_randomFillSync_6f956029658662ec = function(arg0, arg1, arg2) {
getObject(arg0).randomFillSync(getArrayU8FromWasm0(arg1, arg2));
};
export const __wbindgen_string_get = function(arg0, arg1) {

@@ -671,10 +751,6 @@ const obj = getObject(arg1);

export const __wbindgen_rethrow = function(arg0) {
throw takeObject(arg0);
};
export const __wbindgen_closure_wrapper855 = function(arg0, arg1, arg2) {
var ret = makeMutClosure(arg0, arg1, 186, __wbg_adapter_20);
export const __wbindgen_closure_wrapper952 = function(arg0, arg1, arg2) {
var ret = makeMutClosure(arg0, arg1, 227, __wbg_adapter_24);
return addHeapObject(ret);
};
/* tslint:disable */
/* eslint-disable */
/**
* Parses a CSL style, either independent or dependent, and returns its metadata.
* @param {string} style
* @returns {WasmResult<StyleMeta>}
*/
export function parseStyleMetadata(style: string): WasmResult<StyleMeta>;
interface InitOptions {
/** A CSL style as an XML string */
style: string,
/** A Fetcher implementation for fetching locales.
*
* If not provided, then no locales can be fetched, and default-locale and localeOverride will
* not be respected; the only locale used will be the bundled en-US. */
fetcher?: Fetcher,
/** The output format for this driver instance */
format: "html" | "rtf" | "plain",
/** A locale to use instead of the style's default-locale.
*
* For dependent styles, use parseStyleMetadata to find out which locale it prefers, and pass
* in the parent style with a localeOverride set to that value.
*/
localeOverride?: string,
/** Disables sorting in the bibliography; items appear in cited order. */
bibliographyNoSort?: bool,
}
/** This interface lets citeproc retrieve locales or modules asynchronously,
according to which ones are needed. */
export interface Lifecycle {
export interface Fetcher {
/** Return locale XML for a particular locale. */

@@ -12,2 +41,4 @@ fetchLocale(lang: string): Promise<string>;

export type DateLiteral = { "literal": string; };

@@ -21,2 +52,4 @@ export type DateRaw = { "raw": string; };

/** Locator type, and a locator string */

@@ -29,16 +62,16 @@ export type Locator = {

export type CiteLocator = Locator | { locator: undefined; locators: Locator[] };
export type CiteLocator = Locator | { locator: undefined; locators: Locator[]; };
export type CiteMode = { mode?: "SuppressAuthor" | "AuthorOnly"; };
export type Cite<Affix = string> = {
export type Cite = {
id: string;
prefix?: Affix;
suffix?: Affix;
suppression?: "InText" | "Rest" | null;
} & Partial<CiteLocator>;
prefix?: string;
suffix?: string;
} & Partial<CiteLocator> & CiteMode;
export type ClusterNumber = {
note: number | [number, number]
} | {
inText: number
};
export type ClusterMode
= { mode: "Composite"; infix?: string; suppressFirst?: number; }
| { mode: "SuppressAuthor"; suppressFirst?: number; }
| { mode: "AuthorOnly"; }
| {};

@@ -48,4 +81,8 @@ export type Cluster = {

cites: Cite[];
};
} & ClusterMode;
export type PreviewCluster {
cites: Cite[];
} & ClusterMode;
export type ClusterPosition = {

@@ -57,2 +94,4 @@ id: string;

export type Reference = {

@@ -64,6 +103,8 @@ id: string;

export type CslType = "book" | "article" | "legal_case" | "article-journal";
export type CslType = "book" | "article" | "legal_case" | "article-journal" | string;
export interface BibliographyUpdate {
updatedEntries: { [key: string]: string };
updatedEntries: Map<string, string>;
entryIds?: string[];

@@ -77,19 +118,2 @@ }

type InvalidCsl = {
severity: "Error" | "Warning";
range: {
start: number;
end: number;
};
message: string;
hint: string;
};
type ParseError = {
ParseError: string;
};
type Invalid = {
Invalid: InvalidCsl[];
};
type StyleError = Partial<ParseError & Invalid>;
type IncludeUncited = "None" | "All" | { Specific: string[] };

@@ -105,3 +129,3 @@

type FullRender = {
allClusters: { [clusterId: string]: string },
allClusters: Map<string, string>,
bibEntries: BibEntries,

@@ -111,6 +135,6 @@ };

type BibliographyMeta = {
max_offset: number;
entry_spacing: number;
line_spacing: number;
hanging_indent: boolean;
maxOffset: number;
entrySpacing: number;
lineSpacing: number;
hangingIndent: boolean;
/** the second-field-align value of the CSL style */

@@ -123,2 +147,128 @@ secondFieldAlign: null | "flush" | "margin";

type Severity = "Error" | "Warning";
interface InvalidCsl {
severity: Severity;
/** Relevant bytes in the provided XML */
range: {
start: number,
end: number,
};
message: string;
hint: string | undefined;
};
type StyleError = {
tag: "Invalid",
content: InvalidCsl[],
} | {
tag: "ParseError",
content: string,
} | {
/** Cannot use a dependent style to format citations, pass the parent style instead. */
tag: "DependentStyle",
content: {
requiredParent: string,
}
};
type DriverError = {
tag: "UnknownOutputFormat",
content: string,
} | {
tag: "JsonError",
} | {
tag: "GetFetcherError",
} | {
tag: "NonExistentCluster",
content: string,
} | {
tag: "ReorderingError"
} | {
tag: "ReorderingErrorNumericId"
};
declare global {
/** Catch-all citeproc-rs Error subclass. */
declare class CiteprocRsError extends Error {
constructor(message: string);
}
declare class CiteprocRsDriverError extends CiteprocRsError {
data: DriverError;
constructor(message: string, data: DriverError);
}
declare class CslStyleError extends CiteprocRsError {
data: StyleError;
constructor(message: string, data: StyleError);
}
}
interface WasmResult<T> {
/** If this is an error, throws the error. */
unwrap(): T;
/** If this is an error, returns it, else throws. */
unwrap_err(): Error;
is_ok(): boolean;
is_err(): boolean;
/** If this is an error, returns the default value. */
unwrap_or(default: T): T;
/** If this is Ok, returns f(ok_val), else returns Err unmodified. */
map<R>(f: (t: T) => R): WasmResult<T>;
/** If this is Ok, returns f(ok_val), else returns the default value. */
map_or<R>(default: R, f: (t: T) => R): R;
}
type CitationFormat = "author-date" | "author" | "numeric" | "label" | "note";
interface LocalizedString {
value: string,
lang?: string,
}
interface ParentLink {
href: string,
lang?: string,
}
interface Link {
href: string,
rel: "self" | "documentation" | "template",
lang?: string,
}
interface Rights {
value: string,
lang?: string,
license?: string,
}
interface StyleInfo {
id: string,
updated: string,
title: LocalizedString,
titleShort?: LocalizedString,
parent?: ParentLink,
links: Link[],
rights?: Rights,
citationFormat?: CitationFormat,
categories: string[],
issn?: string,
eissn?: string,
issnl?: string,
}
interface IndependentMeta {
/** A list of languages for which a locale override was specified.
* Does not include the language-less final override. */
localeOverrides: string[],
hasBibliography: bool,
}
interface StyleMeta {
info: StyleInfo,
features: { [feature: string]: bool },
defaultLocale: string,
/** May be absent on a dependent style */
class?: "in-text" | "note",
cslVersionRequired: string,
/** May be absent on a dependent style */
independentMeta?: IndependentMeta,
};
/**

@@ -132,29 +282,30 @@ */

* * `style` is a CSL style as a string. Independent styles only.
* * `lifecycle` must implement the `Lifecycle` interface
* * `fetcher` must implement the `Fetcher` interface
* * `format` is one of { "html", "rtf" }
*
* Throws an error if it cannot parse the style you gave it.
* @param {string} style
* @param {any} lifecycle
* @param {string} format
* @returns {Driver}
* @param {InitOptions} options
* @returns {WasmResult<Driver>}
*/
static new(style: string, lifecycle: any, format: string): Driver;
static new(options: InitOptions): WasmResult<Driver>;
/**
* Sets the style (which will also cause everything to be recomputed)
* @param {string} style_text
* @param {string} style_text
* @returns {WasmResult<undefined>}
*/
setStyle(style_text: string): void;
setStyle(style_text: string): WasmResult<undefined>;
/**
* Completely overwrites the references library.
* This **will** delete references that are not in the provided list.
* @param {any[]} refs
* @param {any[]} refs
* @returns {WasmResult<undefined>}
*/
resetReferences(refs: any[]): void;
resetReferences(refs: any[]): WasmResult<undefined>;
/**
* Inserts or overwrites references as a batch operation.
* This **will not** delete references that are not in the provided list.
* @param {any[]} refs
* @param {any[]} refs
* @returns {WasmResult<undefined>}
*/
insertReferences(refs: any[]): void;
insertReferences(refs: any[]): WasmResult<undefined>;
/**

@@ -164,11 +315,13 @@ * Inserts or overwrites a reference.

* * `refr` is a Reference object.
* @param {Reference} refr
* @param {Reference} refr
* @returns {WasmResult<undefined>}
*/
insertReference(refr: Reference): void;
insertReference(refr: Reference): WasmResult<undefined>;
/**
* Removes a reference by id. If it is cited, any cites will be dangling. It will also
* disappear from the bibliography.
* @param {string} id
* @param {string} id
* @returns {WasmResult<undefined>}
*/
removeReference(id: string): void;
removeReference(id: string): WasmResult<undefined>;
/**

@@ -178,5 +331,6 @@ * Sets the references to be included in the bibliography despite not being directly cited.

* * `refr` is a
* @param {IncludeUncited} uncited
* @param {IncludeUncited} uncited
* @returns {WasmResult<undefined>}
*/
includeUncited(uncited: IncludeUncited): void;
includeUncited(uncited: IncludeUncited): WasmResult<undefined>;
/**

@@ -186,8 +340,8 @@ * Gets a list of locales in use by the references currently loaded.

* Note that Driver comes pre-loaded with the `en-US` locale.
* @returns {any}
* @returns {WasmResult<string[]>}
*/
toFetch(): any;
toFetch(): WasmResult<string[]>;
/**
* Returns a random cluster id, with an extra guarantee that it isn't already in use.
* @returns {string}
* @returns {string}
*/

@@ -197,10 +351,12 @@ randomClusterId(): string;

* Inserts or replaces a cluster with a matching `id`.
* @param {any} cluster
* @param {Cluster} cluster
* @returns {WasmResult<undefined>}
*/
insertCluster(cluster: any): void;
insertCluster(cluster: Cluster): WasmResult<undefined>;
/**
* Removes a cluster with a matching `id`
* @param {string} cluster_id
* @param {string} cluster_id
* @returns {WasmResult<undefined>}
*/
removeCluster(cluster_id: string): void;
removeCluster(cluster_id: string): WasmResult<undefined>;
/**

@@ -210,5 +366,6 @@ * Resets all the clusters in the processor to a new list.

* * `clusters` is a Cluster[]
* @param {any[]} clusters
* @param {any[]} clusters
* @returns {WasmResult<undefined>}
*/
initClusters(clusters: any[]): void;
initClusters(clusters: any[]): WasmResult<undefined>;
/**

@@ -219,6 +376,6 @@ * Returns the formatted citation cluster for `cluster_id`.

* still useful for initialization.
* @param {string} id
* @returns {any}
* @param {string} id
* @returns {WasmResult<string>}
*/
builtCluster(id: string): any;
builtCluster(id: string): WasmResult<string>;
/**

@@ -232,16 +389,16 @@ * Previews a formatted citation cluster, in a particular position.

* any location you can think of.
* @param {any[]} cites
* @param {any[]} positions
* @param {string} format
* @returns {any}
* @param {any[]} cites
* @param {any[]} positions
* @param {string} format
* @returns {WasmResult<string>}
*/
previewCitationCluster(cites: any[], positions: any[], format: string): any;
previewCitationCluster(cites: any[], positions: any[], format: string): WasmResult<string>;
/**
* @returns {BibEntries}
* @returns {WasmResult<BibEntries>}
*/
makeBibliography(): BibEntries;
makeBibliography(): WasmResult<BibEntries>;
/**
* @returns {BibliographyMeta}
* @returns {WasmResult<BibliographyMeta>}
*/
bibliographyMeta(): BibliographyMeta;
bibliographyMeta(): WasmResult<BibliographyMeta>;
/**

@@ -271,5 +428,6 @@ * Specifies which clusters are actually considered to be in the document, and sets their

* May error without having set_cluster_ids, but with some set_cluster_note_number-s executed.
* @param {any[]} positions
* @param {any[]} positions
* @returns {WasmResult<undefined>}
*/
setClusterOrder(positions: any[]): void;
setClusterOrder(positions: any[]): WasmResult<undefined>;
/**

@@ -283,5 +441,5 @@ * Retrieve any clusters that have been touched since last time `batchedUpdates` was

* * returns an `UpdateSummary`
* @returns {UpdateSummary}
* @returns {WasmResult<UpdateSummary>}
*/
batchedUpdates(): UpdateSummary;
batchedUpdates(): WasmResult<UpdateSummary>;
/**

@@ -291,5 +449,5 @@ * Returns all the clusters and bibliography entries in the document.

* Use this to rehydrate a document or run non-interactively.
* @returns {FullRender}
* @returns {WasmResult<FullRender>}
*/
fullRender(): FullRender;
fullRender(): WasmResult<FullRender>;
/**

@@ -301,6 +459,6 @@ * Drains the `batchedUpdates` queue manually.

* Asynchronously fetches all the locales that may be required, and saves them into the
* engine. Uses your provided `Lifecycle.fetchLocale` function.
* @returns {Promise<any>}
* engine. Uses your provided `Fetcher.fetchLocale` function.
* @returns {Promise<any>}
*/
fetchAll(): Promise<any>;
fetchLocales(): Promise<any>;
}

@@ -1,303 +0,465 @@

/* tslint:disable */
/* eslint-disable */
/** This interface lets citeproc retrieve locales or modules asynchronously,
according to which ones are needed. */
export interface Lifecycle {
/** Return locale XML for a particular locale. */
fetchLocale(lang: string): Promise<string>;
declare namespace wasm_bindgen {
/* tslint:disable */
/* eslint-disable */
/**
* Parses a CSL style, either independent or dependent, and returns its metadata.
* @param {string} style
* @returns {WasmResult<StyleMeta>}
*/
export function parseStyleMetadata(style: string): WasmResult<StyleMeta>;
interface InitOptions {
/** A CSL style as an XML string */
style: string,
/** A Fetcher implementation for fetching locales.
*
* If not provided, then no locales can be fetched, and default-locale and localeOverride will
* not be respected; the only locale used will be the bundled en-US. */
fetcher?: Fetcher,
/** The output format for this driver instance */
format: "html" | "rtf" | "plain",
/** A locale to use instead of the style's default-locale.
*
* For dependent styles, use parseStyleMetadata to find out which locale it prefers, and pass
* in the parent style with a localeOverride set to that value.
*/
localeOverride?: string,
/** Disables sorting in the bibliography; items appear in cited order. */
bibliographyNoSort?: bool,
}
/** This interface lets citeproc retrieve locales or modules asynchronously,
according to which ones are needed. */
export interface Fetcher {
/** Return locale XML for a particular locale. */
fetchLocale(lang: string): Promise<string>;
}
export type DateLiteral = { "literal": string; };
export type DateRaw = { "raw": string; };
export type DatePartsDate = [number] | [number, number] | [number, number, number];
export type DatePartsSingle = { "date-parts": [DatePartsDate]; };
export type DatePartsRange = { "date-parts": [DatePartsDate, DatePartsDate]; };
export type DateParts = DatePartsSingle | DatePartsRange;
export type DateOrRange = DateLiteral | DateRaw | DateParts;
/** Locator type, and a locator string */
export type Locator = {
label?: string;
locator?: string;
locators: undefined;
};
export type CiteLocator = Locator | { locator: undefined; locators: Locator[]; };
export type CiteMode = { mode?: "SuppressAuthor" | "AuthorOnly"; };
export type Cite = {
id: string;
prefix?: string;
suffix?: string;
} & Partial<CiteLocator> & CiteMode;
export type ClusterMode
= { mode: "Composite"; infix?: string; suppressFirst?: number; }
| { mode: "SuppressAuthor"; suppressFirst?: number; }
| { mode: "AuthorOnly"; }
| {};
export type Cluster = {
id: string;
cites: Cite[];
} & ClusterMode;
export type PreviewCluster {
cites: Cite[];
} & ClusterMode;
export type ClusterPosition = {
id: string;
/** Leaving off this field means this cluster is in-text. */
note?: number;
}
export type Reference = {
id: string;
type: CslType;
[key: string]: any;
};
export type CslType = "book" | "article" | "legal_case" | "article-journal" | string;
export interface BibliographyUpdate {
updatedEntries: Map<string, string>;
entryIds?: string[];
}
export type UpdateSummary<Output = string> = {
clusters: [string, Output][];
bibliography?: BibliographyUpdate;
};
type IncludeUncited = "None" | "All" | { Specific: string[] };
type BibEntry = {
id: string;
value: string;
};
type BibEntries = BibEntry[];
type FullRender = {
allClusters: Map<string, string>,
bibEntries: BibEntries,
};
type BibliographyMeta = {
maxOffset: number;
entrySpacing: number;
lineSpacing: number;
hangingIndent: boolean;
/** the second-field-align value of the CSL style */
secondFieldAlign: null | "flush" | "margin";
/** Format-specific metadata */
formatMeta: any,
};
type Severity = "Error" | "Warning";
interface InvalidCsl {
severity: Severity;
/** Relevant bytes in the provided XML */
range: {
start: number,
end: number,
};
message: string;
hint: string | undefined;
};
type StyleError = {
tag: "Invalid",
content: InvalidCsl[],
} | {
tag: "ParseError",
content: string,
} | {
/** Cannot use a dependent style to format citations, pass the parent style instead. */
tag: "DependentStyle",
content: {
requiredParent: string,
}
};
type DriverError = {
tag: "UnknownOutputFormat",
content: string,
} | {
tag: "JsonError",
} | {
tag: "GetFetcherError",
} | {
tag: "NonExistentCluster",
content: string,
} | {
tag: "ReorderingError"
} | {
tag: "ReorderingErrorNumericId"
};
declare global {
/** Catch-all citeproc-rs Error subclass. */
declare class CiteprocRsError extends Error {
constructor(message: string);
}
declare class CiteprocRsDriverError extends CiteprocRsError {
data: DriverError;
constructor(message: string, data: DriverError);
}
declare class CslStyleError extends CiteprocRsError {
data: StyleError;
constructor(message: string, data: StyleError);
}
}
interface WasmResult<T> {
/** If this is an error, throws the error. */
unwrap(): T;
/** If this is an error, returns it, else throws. */
unwrap_err(): Error;
is_ok(): boolean;
is_err(): boolean;
/** If this is an error, returns the default value. */
unwrap_or(default: T): T;
/** If this is Ok, returns f(ok_val), else returns Err unmodified. */
map<R>(f: (t: T) => R): WasmResult<T>;
/** If this is Ok, returns f(ok_val), else returns the default value. */
map_or<R>(default: R, f: (t: T) => R): R;
}
type CitationFormat = "author-date" | "author" | "numeric" | "label" | "note";
interface LocalizedString {
value: string,
lang?: string,
}
interface ParentLink {
href: string,
lang?: string,
}
interface Link {
href: string,
rel: "self" | "documentation" | "template",
lang?: string,
}
interface Rights {
value: string,
lang?: string,
license?: string,
}
interface StyleInfo {
id: string,
updated: string,
title: LocalizedString,
titleShort?: LocalizedString,
parent?: ParentLink,
links: Link[],
rights?: Rights,
citationFormat?: CitationFormat,
categories: string[],
issn?: string,
eissn?: string,
issnl?: string,
}
interface IndependentMeta {
/** A list of languages for which a locale override was specified.
* Does not include the language-less final override. */
localeOverrides: string[],
hasBibliography: bool,
}
interface StyleMeta {
info: StyleInfo,
features: { [feature: string]: bool },
defaultLocale: string,
/** May be absent on a dependent style */
class?: "in-text" | "note",
cslVersionRequired: string,
/** May be absent on a dependent style */
independentMeta?: IndependentMeta,
};
/**
*/
export class Driver {
free(): void;
/**
* Creates a new Driver.
*
* * `style` is a CSL style as a string. Independent styles only.
* * `fetcher` must implement the `Fetcher` interface
* * `format` is one of { "html", "rtf" }
*
* Throws an error if it cannot parse the style you gave it.
* @param {InitOptions} options
* @returns {WasmResult<Driver>}
*/
static new(options: InitOptions): WasmResult<Driver>;
/**
* Sets the style (which will also cause everything to be recomputed)
* @param {string} style_text
* @returns {WasmResult<undefined>}
*/
setStyle(style_text: string): WasmResult<undefined>;
/**
* Completely overwrites the references library.
* This **will** delete references that are not in the provided list.
* @param {any[]} refs
* @returns {WasmResult<undefined>}
*/
resetReferences(refs: any[]): WasmResult<undefined>;
/**
* Inserts or overwrites references as a batch operation.
* This **will not** delete references that are not in the provided list.
* @param {any[]} refs
* @returns {WasmResult<undefined>}
*/
insertReferences(refs: any[]): WasmResult<undefined>;
/**
* Inserts or overwrites a reference.
*
* * `refr` is a Reference object.
* @param {Reference} refr
* @returns {WasmResult<undefined>}
*/
insertReference(refr: Reference): WasmResult<undefined>;
/**
* Removes a reference by id. If it is cited, any cites will be dangling. It will also
* disappear from the bibliography.
* @param {string} id
* @returns {WasmResult<undefined>}
*/
removeReference(id: string): WasmResult<undefined>;
/**
* Sets the references to be included in the bibliography despite not being directly cited.
*
* * `refr` is a
* @param {IncludeUncited} uncited
* @returns {WasmResult<undefined>}
*/
includeUncited(uncited: IncludeUncited): WasmResult<undefined>;
/**
* Gets a list of locales in use by the references currently loaded.
*
* Note that Driver comes pre-loaded with the `en-US` locale.
* @returns {WasmResult<string[]>}
*/
toFetch(): WasmResult<string[]>;
/**
* Returns a random cluster id, with an extra guarantee that it isn't already in use.
* @returns {string}
*/
randomClusterId(): string;
/**
* Inserts or replaces a cluster with a matching `id`.
* @param {Cluster} cluster
* @returns {WasmResult<undefined>}
*/
insertCluster(cluster: Cluster): WasmResult<undefined>;
/**
* Removes a cluster with a matching `id`
* @param {string} cluster_id
* @returns {WasmResult<undefined>}
*/
removeCluster(cluster_id: string): WasmResult<undefined>;
/**
* Resets all the clusters in the processor to a new list.
*
* * `clusters` is a Cluster[]
* @param {any[]} clusters
* @returns {WasmResult<undefined>}
*/
initClusters(clusters: any[]): WasmResult<undefined>;
/**
* Returns the formatted citation cluster for `cluster_id`.
*
* Prefer `batchedUpdates` to avoid serializing unchanged clusters on every edit. This is
* still useful for initialization.
* @param {string} id
* @returns {WasmResult<string>}
*/
builtCluster(id: string): WasmResult<string>;
/**
* Previews a formatted citation cluster, in a particular position.
*
* - `cites`: The cites to go in the cluster
* - `positions`: An array of `ClusterPosition`s as in set_cluster_order, but with a single
* cluster's id set to zero. The cluster with id=0 is the position to preview the cite. It
* can replace another cluster, or be inserted before/after/between existing clusters, in
* any location you can think of.
* @param {any[]} cites
* @param {any[]} positions
* @param {string} format
* @returns {WasmResult<string>}
*/
previewCitationCluster(cites: any[], positions: any[], format: string): WasmResult<string>;
/**
* @returns {WasmResult<BibEntries>}
*/
makeBibliography(): WasmResult<BibEntries>;
/**
* @returns {WasmResult<BibliographyMeta>}
*/
bibliographyMeta(): WasmResult<BibliographyMeta>;
/**
* Specifies which clusters are actually considered to be in the document, and sets their
* order. You may insert as many clusters as you like, but the ones provided here are the only
* ones used.
*
* If a piece does not provide a note, it is an in-text reference. Generally, this is what you
* should be providing for note styles, such that first-reference-note-number does not gain a
* value, but some users put in-text references inside footnotes, and it is unclear what the
* processor should do in this situation so you could try providing note numbers there as
* well.
*
* If a piece provides a { note: N } field, then that N must be monotically increasing
* throughout the document. Two same-N-in-a-row clusters means they occupy the same footnote,
* e.g. this would be two clusters:
*
* ```text
* Some text with footnote.[Prefix @cite, suffix. Second prefix @another_cite, second suffix.]
* ```
*
* This case is recognised and the order they appear in the input here is the order used for
* determining cite positions (ibid, subsequent, etc). But the position:first cites within
* them will all have the same first-reference-note-number if FRNN is used in later cites.
*
* May error without having set_cluster_ids, but with some set_cluster_note_number-s executed.
* @param {any[]} positions
* @returns {WasmResult<undefined>}
*/
setClusterOrder(positions: any[]): WasmResult<undefined>;
/**
* Retrieve any clusters that have been touched since last time `batchedUpdates` was
* called. Intended to be called every time an edit has been made. Every cluster in the
* returned summary should then be reflected in any UI.
*
* Some built clusters may occasionally have identical contents to before.
*
* * returns an `UpdateSummary`
* @returns {WasmResult<UpdateSummary>}
*/
batchedUpdates(): WasmResult<UpdateSummary>;
/**
* Returns all the clusters and bibliography entries in the document.
* Also drains the queue, just like batchedUpdates().
* Use this to rehydrate a document or run non-interactively.
* @returns {WasmResult<FullRender>}
*/
fullRender(): WasmResult<FullRender>;
/**
* Drains the `batchedUpdates` queue manually.
*/
drain(): void;
/**
* Asynchronously fetches all the locales that may be required, and saves them into the
* engine. Uses your provided `Fetcher.fetchLocale` function.
* @returns {Promise<any>}
*/
fetchLocales(): Promise<any>;
}
}
export type DateLiteral = { "literal": string; };
export type DateRaw = { "raw": string; };
export type DatePartsDate = [number] | [number, number] | [number, number, number];
export type DatePartsSingle = { "date-parts": [DatePartsDate]; };
export type DatePartsRange = { "date-parts": [DatePartsDate, DatePartsDate]; };
export type DateParts = DatePartsSingle | DatePartsRange;
export type DateOrRange = DateLiteral | DateRaw | DateParts;
declare type InitInput = RequestInfo | URL | Response | BufferSource | WebAssembly.Module;
/** Locator type, and a locator string */
export type Locator = {
label?: string;
locator?: string;
locators: undefined;
};
export type CiteLocator = Locator | { locator: undefined; locators: Locator[] };
export type Cite<Affix = string> = {
id: string;
prefix?: Affix;
suffix?: Affix;
suppression?: "InText" | "Rest" | null;
} & Partial<CiteLocator>;
export type ClusterNumber = {
note: number | [number, number]
} | {
inText: number
};
export type Cluster = {
id: string;
cites: Cite[];
};
export type ClusterPosition = {
id: string;
/** Leaving off this field means this cluster is in-text. */
note?: number;
}
export type Reference = {
id: string;
type: CslType;
[key: string]: any;
};
export type CslType = "book" | "article" | "legal_case" | "article-journal";
export interface BibliographyUpdate {
updatedEntries: { [key: string]: string };
entryIds?: string[];
}
export type UpdateSummary<Output = string> = {
clusters: [string, Output][];
bibliography?: BibliographyUpdate;
};
type InvalidCsl = {
severity: "Error" | "Warning";
range: {
start: number;
end: number;
};
message: string;
hint: string;
};
type ParseError = {
ParseError: string;
};
type Invalid = {
Invalid: InvalidCsl[];
};
type StyleError = Partial<ParseError & Invalid>;
type IncludeUncited = "None" | "All" | { Specific: string[] };
type BibEntry = {
id: string;
value: string;
};
type BibEntries = BibEntry[];
type FullRender = {
allClusters: { [clusterId: string]: string },
bibEntries: BibEntries,
};
type BibliographyMeta = {
max_offset: number;
entry_spacing: number;
line_spacing: number;
hanging_indent: boolean;
/** the second-field-align value of the CSL style */
secondFieldAlign: null | "flush" | "margin";
/** Format-specific metadata */
formatMeta: any,
};
/**
*/
export class Driver {
free(): void;
/**
* Creates a new Driver.
*
* * `style` is a CSL style as a string. Independent styles only.
* * `lifecycle` must implement the `Lifecycle` interface
* * `format` is one of { "html", "rtf" }
*
* Throws an error if it cannot parse the style you gave it.
* @param {string} style
* @param {any} lifecycle
* @param {string} format
* @returns {Driver}
*/
static new(style: string, lifecycle: any, format: string): Driver;
/**
* Sets the style (which will also cause everything to be recomputed)
* @param {string} style_text
*/
setStyle(style_text: string): void;
/**
* Completely overwrites the references library.
* This **will** delete references that are not in the provided list.
* @param {any[]} refs
*/
resetReferences(refs: any[]): void;
/**
* Inserts or overwrites references as a batch operation.
* This **will not** delete references that are not in the provided list.
* @param {any[]} refs
*/
insertReferences(refs: any[]): void;
/**
* Inserts or overwrites a reference.
*
* * `refr` is a Reference object.
* @param {Reference} refr
*/
insertReference(refr: Reference): void;
/**
* Removes a reference by id. If it is cited, any cites will be dangling. It will also
* disappear from the bibliography.
* @param {string} id
*/
removeReference(id: string): void;
/**
* Sets the references to be included in the bibliography despite not being directly cited.
*
* * `refr` is a
* @param {IncludeUncited} uncited
*/
includeUncited(uncited: IncludeUncited): void;
/**
* Gets a list of locales in use by the references currently loaded.
*
* Note that Driver comes pre-loaded with the `en-US` locale.
* @returns {any}
*/
toFetch(): any;
/**
* Returns a random cluster id, with an extra guarantee that it isn't already in use.
* @returns {string}
*/
randomClusterId(): string;
/**
* Inserts or replaces a cluster with a matching `id`.
* @param {any} cluster
*/
insertCluster(cluster: any): void;
/**
* Removes a cluster with a matching `id`
* @param {string} cluster_id
*/
removeCluster(cluster_id: string): void;
/**
* Resets all the clusters in the processor to a new list.
*
* * `clusters` is a Cluster[]
* @param {any[]} clusters
*/
initClusters(clusters: any[]): void;
/**
* Returns the formatted citation cluster for `cluster_id`.
*
* Prefer `batchedUpdates` to avoid serializing unchanged clusters on every edit. This is
* still useful for initialization.
* @param {string} id
* @returns {any}
*/
builtCluster(id: string): any;
/**
* Previews a formatted citation cluster, in a particular position.
*
* - `cites`: The cites to go in the cluster
* - `positions`: An array of `ClusterPosition`s as in set_cluster_order, but with a single
* cluster's id set to zero. The cluster with id=0 is the position to preview the cite. It
* can replace another cluster, or be inserted before/after/between existing clusters, in
* any location you can think of.
* @param {any[]} cites
* @param {any[]} positions
* @param {string} format
* @returns {any}
*/
previewCitationCluster(cites: any[], positions: any[], format: string): any;
/**
* @returns {BibEntries}
*/
makeBibliography(): BibEntries;
/**
* @returns {BibliographyMeta}
*/
bibliographyMeta(): BibliographyMeta;
/**
* Specifies which clusters are actually considered to be in the document, and sets their
* order. You may insert as many clusters as you like, but the ones provided here are the only
* ones used.
*
* If a piece does not provide a note, it is an in-text reference. Generally, this is what you
* should be providing for note styles, such that first-reference-note-number does not gain a
* value, but some users put in-text references inside footnotes, and it is unclear what the
* processor should do in this situation so you could try providing note numbers there as
* well.
*
* If a piece provides a { note: N } field, then that N must be monotically increasing
* throughout the document. Two same-N-in-a-row clusters means they occupy the same footnote,
* e.g. this would be two clusters:
*
* ```text
* Some text with footnote.[Prefix @cite, suffix. Second prefix @another_cite, second suffix.]
* ```
*
* This case is recognised and the order they appear in the input here is the order used for
* determining cite positions (ibid, subsequent, etc). But the position:first cites within
* them will all have the same first-reference-note-number if FRNN is used in later cites.
*
* May error without having set_cluster_ids, but with some set_cluster_note_number-s executed.
* @param {any[]} positions
*/
setClusterOrder(positions: any[]): void;
/**
* Retrieve any clusters that have been touched since last time `batchedUpdates` was
* called. Intended to be called every time an edit has been made. Every cluster in the
* returned summary should then be reflected in any UI.
*
* Some built clusters may occasionally have identical contents to before.
*
* * returns an `UpdateSummary`
* @returns {UpdateSummary}
*/
batchedUpdates(): UpdateSummary;
/**
* Returns all the clusters and bibliography entries in the document.
* Also drains the queue, just like batchedUpdates().
* Use this to rehydrate a document or run non-interactively.
* @returns {FullRender}
*/
fullRender(): FullRender;
/**
* Drains the `batchedUpdates` queue manually.
*/
drain(): void;
/**
* Asynchronously fetches all the locales that may be required, and saves them into the
* engine. Uses your provided `Lifecycle.fetchLocale` function.
* @returns {Promise<any>}
*/
fetchAll(): Promise<any>;
}
export type InitInput = RequestInfo | URL | Response | BufferSource | WebAssembly.Module;
export interface InitOutput {
declare interface InitOutput {
readonly memory: WebAssembly.Memory;
readonly parseStyleMetadata: (a: number, b: number) => number;
readonly __wbg_driver_free: (a: number) => void;
readonly driver_new: (a: number, b: number, c: number, d: number, e: number) => number;
readonly driver_setStyle: (a: number, b: number, c: number) => void;
readonly driver_resetReferences: (a: number, b: number, c: number) => void;
readonly driver_insertReferences: (a: number, b: number, c: number) => void;
readonly driver_insertReference: (a: number, b: number) => void;
readonly driver_removeReference: (a: number, b: number, c: number) => void;
readonly driver_includeUncited: (a: number, b: number) => void;
readonly driver_new: (a: number) => number;
readonly driver_setStyle: (a: number, b: number, c: number) => number;
readonly driver_resetReferences: (a: number, b: number, c: number) => number;
readonly driver_insertReferences: (a: number, b: number, c: number) => number;
readonly driver_insertReference: (a: number, b: number) => number;
readonly driver_removeReference: (a: number, b: number, c: number) => number;
readonly driver_includeUncited: (a: number, b: number) => number;
readonly driver_toFetch: (a: number) => number;
readonly driver_randomClusterId: (a: number, b: number) => void;
readonly driver_insertCluster: (a: number, b: number) => void;
readonly driver_removeCluster: (a: number, b: number, c: number) => void;
readonly driver_initClusters: (a: number, b: number, c: number) => void;
readonly driver_insertCluster: (a: number, b: number) => number;
readonly driver_removeCluster: (a: number, b: number, c: number) => number;
readonly driver_initClusters: (a: number, b: number, c: number) => number;
readonly driver_builtCluster: (a: number, b: number, c: number) => number;

@@ -307,14 +469,15 @@ readonly driver_previewCitationCluster: (a: number, b: number, c: number, d: number, e: number, f: number, g: number) => number;

readonly driver_bibliographyMeta: (a: number) => number;
readonly driver_setClusterOrder: (a: number, b: number, c: number) => void;
readonly driver_setClusterOrder: (a: number, b: number, c: number) => number;
readonly driver_batchedUpdates: (a: number) => number;
readonly driver_fullRender: (a: number) => number;
readonly driver_drain: (a: number) => void;
readonly driver_fetchAll: (a: number) => number;
readonly driver_fetchLocales: (a: number) => number;
readonly __wbindgen_malloc: (a: number) => number;
readonly __wbindgen_realloc: (a: number, b: number, c: number) => number;
readonly __wbindgen_export_2: WebAssembly.Table;
readonly _dyn_core__ops__function__FnMut__A____Output___R_as_wasm_bindgen__closure__WasmClosure___describe__invoke__hc76d7ca4c06d1374: (a: number, b: number, c: number) => void;
readonly _dyn_core__ops__function__FnMut__A____Output___R_as_wasm_bindgen__closure__WasmClosure___describe__invoke__h2b1b33880a98c55e: (a: number, b: number, c: number) => void;
readonly __wbindgen_add_to_stack_pointer: (a: number) => number;
readonly __wbindgen_free: (a: number, b: number) => void;
readonly __wbindgen_exn_store: (a: number) => void;
readonly wasm_bindgen__convert__closures__invoke2_mut__h982cd7b8d71edcca: (a: number, b: number, c: number, d: number) => void;
readonly wasm_bindgen__convert__closures__invoke2_mut__h4915090d68cfd6bd: (a: number, b: number, c: number, d: number) => void;
}

@@ -330,3 +493,2 @@

*/
export default function init (module_or_path?: InitInput | Promise<InitInput>): Promise<InitOutput>;
declare function wasm_bindgen (module_or_path?: InitInput | Promise<InitInput>): Promise<InitOutput>;

@@ -119,3 +119,3 @@ let wasm_bindgen;

function makeMutClosure(arg0, arg1, dtor, f) {
const state = { a: arg0, b: arg1, cnt: 1 };
const state = { a: arg0, b: arg1, cnt: 1, dtor };
const real = (...args) => {

@@ -131,13 +131,30 @@ // First up with a closure we increment the internal reference

} finally {
if (--state.cnt === 0) wasm.__wbindgen_export_2.get(dtor)(a, state.b);
else state.a = a;
if (--state.cnt === 0) {
wasm.__wbindgen_export_2.get(state.dtor)(a, state.b);
} else {
state.a = a;
}
}
};
real.original = state;
return real;
}
function __wbg_adapter_20(arg0, arg1, arg2) {
wasm._dyn_core__ops__function__FnMut__A____Output___R_as_wasm_bindgen__closure__WasmClosure___describe__invoke__hc76d7ca4c06d1374(arg0, arg1, addHeapObject(arg2));
function __wbg_adapter_24(arg0, arg1, arg2) {
wasm._dyn_core__ops__function__FnMut__A____Output___R_as_wasm_bindgen__closure__WasmClosure___describe__invoke__h2b1b33880a98c55e(arg0, arg1, addHeapObject(arg2));
}
/**
* Parses a CSL style, either independent or dependent, and returns its metadata.
* @param {string} style
* @returns {WasmResult<StyleMeta>}
*/
__exports.parseStyleMetadata = function(style) {
var ptr0 = passStringToWasm0(style, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
var len0 = WASM_VECTOR_LEN;
var ret = wasm.parseStyleMetadata(ptr0, len0);
return takeObject(ret);
};
let cachegetUint32Memory0 = null;

@@ -171,4 +188,4 @@ function getUint32Memory0() {

}
function __wbg_adapter_66(arg0, arg1, arg2, arg3) {
wasm.wasm_bindgen__convert__closures__invoke2_mut__h982cd7b8d71edcca(arg0, arg1, addHeapObject(arg2), addHeapObject(arg3));
function __wbg_adapter_81(arg0, arg1, arg2, arg3) {
wasm.wasm_bindgen__convert__closures__invoke2_mut__h4915090d68cfd6bd(arg0, arg1, addHeapObject(arg2), addHeapObject(arg3));
}

@@ -190,6 +207,11 @@

free() {
__destroy_into_raw() {
const ptr = this.ptr;
this.ptr = 0;
return ptr;
}
free() {
const ptr = this.__destroy_into_raw();
wasm.__wbg_driver_free(ptr);

@@ -201,18 +223,12 @@ }

* * `style` is a CSL style as a string. Independent styles only.
* * `lifecycle` must implement the `Lifecycle` interface
* * `fetcher` must implement the `Fetcher` interface
* * `format` is one of { "html", "rtf" }
*
* Throws an error if it cannot parse the style you gave it.
* @param {string} style
* @param {any} lifecycle
* @param {string} format
* @returns {Driver}
* @param {InitOptions} options
* @returns {WasmResult<Driver>}
*/
static new(style, lifecycle, format) {
var ptr0 = passStringToWasm0(style, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
var len0 = WASM_VECTOR_LEN;
var ptr1 = passStringToWasm0(format, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
var len1 = WASM_VECTOR_LEN;
var ret = wasm.driver_new(ptr0, len0, addHeapObject(lifecycle), ptr1, len1);
return Driver.__wrap(ret);
static new(options) {
var ret = wasm.driver_new(addHeapObject(options));
return takeObject(ret);
}

@@ -222,2 +238,3 @@ /**

* @param {string} style_text
* @returns {WasmResult<undefined>}
*/

@@ -227,3 +244,4 @@ setStyle(style_text) {

var len0 = WASM_VECTOR_LEN;
wasm.driver_setStyle(this.ptr, ptr0, len0);
var ret = wasm.driver_setStyle(this.ptr, ptr0, len0);
return takeObject(ret);
}

@@ -234,2 +252,3 @@ /**

* @param {any[]} refs
* @returns {WasmResult<undefined>}
*/

@@ -239,3 +258,4 @@ resetReferences(refs) {

var len0 = WASM_VECTOR_LEN;
wasm.driver_resetReferences(this.ptr, ptr0, len0);
var ret = wasm.driver_resetReferences(this.ptr, ptr0, len0);
return takeObject(ret);
}

@@ -246,2 +266,3 @@ /**

* @param {any[]} refs
* @returns {WasmResult<undefined>}
*/

@@ -251,3 +272,4 @@ insertReferences(refs) {

var len0 = WASM_VECTOR_LEN;
wasm.driver_insertReferences(this.ptr, ptr0, len0);
var ret = wasm.driver_insertReferences(this.ptr, ptr0, len0);
return takeObject(ret);
}

@@ -259,5 +281,7 @@ /**

* @param {Reference} refr
* @returns {WasmResult<undefined>}
*/
insertReference(refr) {
wasm.driver_insertReference(this.ptr, addHeapObject(refr));
var ret = wasm.driver_insertReference(this.ptr, addHeapObject(refr));
return takeObject(ret);
}

@@ -268,2 +292,3 @@ /**

* @param {string} id
* @returns {WasmResult<undefined>}
*/

@@ -273,3 +298,4 @@ removeReference(id) {

var len0 = WASM_VECTOR_LEN;
wasm.driver_removeReference(this.ptr, ptr0, len0);
var ret = wasm.driver_removeReference(this.ptr, ptr0, len0);
return takeObject(ret);
}

@@ -281,5 +307,7 @@ /**

* @param {IncludeUncited} uncited
* @returns {WasmResult<undefined>}
*/
includeUncited(uncited) {
wasm.driver_includeUncited(this.ptr, addHeapObject(uncited));
var ret = wasm.driver_includeUncited(this.ptr, addHeapObject(uncited));
return takeObject(ret);
}

@@ -290,3 +318,3 @@ /**

* Note that Driver comes pre-loaded with the `en-US` locale.
* @returns {any}
* @returns {WasmResult<string[]>}
*/

@@ -303,7 +331,9 @@ toFetch() {

try {
wasm.driver_randomClusterId(8, this.ptr);
var r0 = getInt32Memory0()[8 / 4 + 0];
var r1 = getInt32Memory0()[8 / 4 + 1];
const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);
wasm.driver_randomClusterId(retptr, this.ptr);
var r0 = getInt32Memory0()[retptr / 4 + 0];
var r1 = getInt32Memory0()[retptr / 4 + 1];
return getStringFromWasm0(r0, r1);
} finally {
wasm.__wbindgen_add_to_stack_pointer(16);
wasm.__wbindgen_free(r0, r1);

@@ -314,6 +344,8 @@ }

* Inserts or replaces a cluster with a matching `id`.
* @param {any} cluster
* @param {Cluster} cluster
* @returns {WasmResult<undefined>}
*/
insertCluster(cluster) {
wasm.driver_insertCluster(this.ptr, addHeapObject(cluster));
var ret = wasm.driver_insertCluster(this.ptr, addHeapObject(cluster));
return takeObject(ret);
}

@@ -323,2 +355,3 @@ /**

* @param {string} cluster_id
* @returns {WasmResult<undefined>}
*/

@@ -328,3 +361,4 @@ removeCluster(cluster_id) {

var len0 = WASM_VECTOR_LEN;
wasm.driver_removeCluster(this.ptr, ptr0, len0);
var ret = wasm.driver_removeCluster(this.ptr, ptr0, len0);
return takeObject(ret);
}

@@ -336,2 +370,3 @@ /**

* @param {any[]} clusters
* @returns {WasmResult<undefined>}
*/

@@ -341,3 +376,4 @@ initClusters(clusters) {

var len0 = WASM_VECTOR_LEN;
wasm.driver_initClusters(this.ptr, ptr0, len0);
var ret = wasm.driver_initClusters(this.ptr, ptr0, len0);
return takeObject(ret);
}

@@ -350,3 +386,3 @@ /**

* @param {string} id
* @returns {any}
* @returns {WasmResult<string>}
*/

@@ -370,3 +406,3 @@ builtCluster(id) {

* @param {string} format
* @returns {any}
* @returns {WasmResult<string>}
*/

@@ -384,3 +420,3 @@ previewCitationCluster(cites, positions, format) {

/**
* @returns {BibEntries}
* @returns {WasmResult<BibEntries>}
*/

@@ -392,3 +428,3 @@ makeBibliography() {

/**
* @returns {BibliographyMeta}
* @returns {WasmResult<BibliographyMeta>}
*/

@@ -424,2 +460,3 @@ bibliographyMeta() {

* @param {any[]} positions
* @returns {WasmResult<undefined>}
*/

@@ -429,3 +466,4 @@ setClusterOrder(positions) {

var len0 = WASM_VECTOR_LEN;
wasm.driver_setClusterOrder(this.ptr, ptr0, len0);
var ret = wasm.driver_setClusterOrder(this.ptr, ptr0, len0);
return takeObject(ret);
}

@@ -440,3 +478,3 @@ /**

* * returns an `UpdateSummary`
* @returns {UpdateSummary}
* @returns {WasmResult<UpdateSummary>}
*/

@@ -451,3 +489,3 @@ batchedUpdates() {

* Use this to rehydrate a document or run non-interactively.
* @returns {FullRender}
* @returns {WasmResult<FullRender>}
*/

@@ -466,7 +504,7 @@ fullRender() {

* Asynchronously fetches all the locales that may be required, and saves them into the
* engine. Uses your provided `Lifecycle.fetchLocale` function.
* engine. Uses your provided `Fetcher.fetchLocale` function.
* @returns {Promise<any>}
*/
fetchAll() {
var ret = wasm.driver_fetchAll(this.ptr);
fetchLocales() {
var ret = wasm.driver_fetchLocales(this.ptr);
return takeObject(ret);

@@ -479,3 +517,2 @@ }

if (typeof Response === 'function' && module instanceof Response) {
if (typeof WebAssembly.instantiateStreaming === 'function') {

@@ -499,3 +536,2 @@ try {

} else {
const instance = await WebAssembly.instantiate(module, imports);

@@ -530,2 +566,17 @@

};
imports.wbg.__wbg_debug_4885c3f7d6f044a3 = function(arg0, arg1) {
console.debug(getStringFromWasm0(arg0, arg1));
};
imports.wbg.__wbg_log_bee3ea1a89f334d8 = function(arg0, arg1) {
console.log(getStringFromWasm0(arg0, arg1));
};
imports.wbg.__wbg_info_0547ff9513f2019b = function(arg0, arg1) {
console.info(getStringFromWasm0(arg0, arg1));
};
imports.wbg.__wbg_warn_a478dea6e6e05394 = function(arg0, arg1) {
console.warn(getStringFromWasm0(arg0, arg1));
};
imports.wbg.__wbg_error_72e88ba6901b6eee = function(arg0, arg1) {
console.error(getStringFromWasm0(arg0, arg1));
};
imports.wbg.__wbindgen_json_serialize = function(arg0, arg1) {

@@ -539,14 +590,6 @@ const obj = getObject(arg1);

};
imports.wbg.__wbindgen_json_parse = function(arg0, arg1) {
var ret = JSON.parse(getStringFromWasm0(arg0, arg1));
imports.wbg.__wbindgen_string_new = function(arg0, arg1) {
var ret = getStringFromWasm0(arg0, arg1);
return addHeapObject(ret);
};
imports.wbg.__wbg_fetchLocale_8f52b973b0739a6c = function(arg0, arg1, arg2) {
var ret = getObject(arg0).fetchLocale(getStringFromWasm0(arg1, arg2));
return addHeapObject(ret);
};
imports.wbg.__wbindgen_object_clone_ref = function(arg0) {
var ret = getObject(arg0);
return addHeapObject(ret);
};
imports.wbg.__wbindgen_cb_drop = function(arg0) {

@@ -561,17 +604,51 @@ const obj = takeObject(arg0).original;

};
imports.wbg.__wbg_debug_4885c3f7d6f044a3 = function(arg0, arg1) {
console.debug(getStringFromWasm0(arg0, arg1));
imports.wbg.__wbindgen_json_parse = function(arg0, arg1) {
var ret = JSON.parse(getStringFromWasm0(arg0, arg1));
return addHeapObject(ret);
};
imports.wbg.__wbg_log_bee3ea1a89f334d8 = function(arg0, arg1) {
console.log(getStringFromWasm0(arg0, arg1));
imports.wbg.__wbg_driver_new = function(arg0) {
var ret = Driver.__wrap(arg0);
return addHeapObject(ret);
};
imports.wbg.__wbg_info_0547ff9513f2019b = function(arg0, arg1) {
console.info(getStringFromWasm0(arg0, arg1));
imports.wbg.__wbg_new_1f7db38dfd81bf2f = function(arg0) {
var ret = new CiteprocRsError(takeObject(arg0));
return addHeapObject(ret);
};
imports.wbg.__wbg_warn_a478dea6e6e05394 = function(arg0, arg1) {
console.warn(getStringFromWasm0(arg0, arg1));
imports.wbg.__wbg_new_bb3cad8cb87701ce = function(arg0, arg1) {
var ret = new CslStyleError(takeObject(arg0), takeObject(arg1));
return addHeapObject(ret);
};
imports.wbg.__wbg_error_72e88ba6901b6eee = function(arg0, arg1) {
console.error(getStringFromWasm0(arg0, arg1));
imports.wbg.__wbg_new_90da75e9c7c4fa61 = function(arg0) {
var ret = new WasmResult(takeObject(arg0));
return addHeapObject(ret);
};
imports.wbg.__wbg_get_1edc26456ed84f9b = function(arg0, arg1) {
var ret = getObject(arg0)[takeObject(arg1)];
return addHeapObject(ret);
};
imports.wbg.__wbg_new_16465ddabcb4a719 = function(arg0, arg1) {
var ret = new CiteprocRsDriverError(takeObject(arg0), takeObject(arg1));
return addHeapObject(ret);
};
imports.wbg.__wbindgen_object_clone_ref = function(arg0) {
var ret = getObject(arg0);
return addHeapObject(ret);
};
imports.wbg.__wbindgen_is_undefined = function(arg0) {
var ret = getObject(arg0) === undefined;
return ret;
};
imports.wbg.__wbindgen_is_object = function(arg0) {
const val = getObject(arg0);
var ret = typeof(val) === 'object' && val !== null;
return ret;
};
imports.wbg.__wbindgen_is_function = function(arg0) {
var ret = typeof(getObject(arg0)) === 'function';
return ret;
};
imports.wbg.__wbg_fetchLocale_d644d4ae2ca50f81 = function(arg0, arg1, arg2) {
var ret = getObject(arg0).fetchLocale(getStringFromWasm0(arg1, arg2));
return addHeapObject(ret);
};
imports.wbg.__wbg_new_59cb74e423758ede = function() {

@@ -595,11 +672,7 @@ var ret = new Error();

};
imports.wbg.__wbg_new_1d56e97b8de3067f = function(arg0, arg1) {
var ret = new Error(getStringFromWasm0(arg0, arg1));
return addHeapObject(ret);
};
imports.wbg.__wbg_call_0246f1c8ff252fb6 = handleError(function(arg0, arg1, arg2) {
imports.wbg.__wbg_call_f5e0576f61ee7461 = handleError(function(arg0, arg1, arg2) {
var ret = getObject(arg0).call(getObject(arg1), getObject(arg2));
return addHeapObject(ret);
});
imports.wbg.__wbg_new_09f2ad087112acf0 = function(arg0, arg1) {
imports.wbg.__wbg_new_3ea8490cd276c848 = function(arg0, arg1) {
try {

@@ -611,3 +684,3 @@ var state0 = {a: arg0, b: arg1};

try {
return __wbg_adapter_66(a, state0.b, arg0, arg1);
return __wbg_adapter_81(a, state0.b, arg0, arg1);
} finally {

@@ -623,24 +696,14 @@ state0.a = a;

};
imports.wbg.__wbg_resolve_708df7651c8929b8 = function(arg0) {
imports.wbg.__wbg_resolve_778af3f90b8e2b59 = function(arg0) {
var ret = Promise.resolve(getObject(arg0));
return addHeapObject(ret);
};
imports.wbg.__wbg_then_8c23dce80c84c8fb = function(arg0, arg1) {
imports.wbg.__wbg_then_367b3e718069cfb9 = function(arg0, arg1) {
var ret = getObject(arg0).then(getObject(arg1));
return addHeapObject(ret);
};
imports.wbg.__wbg_then_300153bb889a5b4b = function(arg0, arg1, arg2) {
imports.wbg.__wbg_then_ac66ca61394bfd21 = function(arg0, arg1, arg2) {
var ret = getObject(arg0).then(getObject(arg1), getObject(arg2));
return addHeapObject(ret);
};
imports.wbg.__wbindgen_is_undefined = function(arg0) {
var ret = getObject(arg0) === undefined;
return ret;
};
imports.wbg.__wbg_getRandomValues_3ac1b33c90b52596 = function(arg0, arg1, arg2) {
getObject(arg0).getRandomValues(getArrayU8FromWasm0(arg1, arg2));
};
imports.wbg.__wbg_randomFillSync_6f956029658662ec = function(arg0, arg1, arg2) {
getObject(arg0).randomFillSync(getArrayU8FromWasm0(arg1, arg2));
};
imports.wbg.__wbg_self_1c83eb4471d9eb9b = handleError(function() {

@@ -670,2 +733,8 @@ var ret = self.self;

};
imports.wbg.__wbg_getRandomValues_3ac1b33c90b52596 = function(arg0, arg1, arg2) {
getObject(arg0).getRandomValues(getArrayU8FromWasm0(arg1, arg2));
};
imports.wbg.__wbg_randomFillSync_6f956029658662ec = function(arg0, arg1, arg2) {
getObject(arg0).randomFillSync(getArrayU8FromWasm0(arg1, arg2));
};
imports.wbg.__wbindgen_string_get = function(arg0, arg1) {

@@ -682,7 +751,4 @@ const obj = getObject(arg1);

};
imports.wbg.__wbindgen_rethrow = function(arg0) {
throw takeObject(arg0);
};
imports.wbg.__wbindgen_closure_wrapper855 = function(arg0, arg1, arg2) {
var ret = makeMutClosure(arg0, arg1, 186, __wbg_adapter_20);
imports.wbg.__wbindgen_closure_wrapper952 = function(arg0, arg1, arg2) {
var ret = makeMutClosure(arg0, arg1, 227, __wbg_adapter_24);
return addHeapObject(ret);

@@ -695,2 +761,4 @@ };

const { instance, module } = await load(await input, imports);

@@ -697,0 +765,0 @@

/* tslint:disable */
/* eslint-disable */
/**
* Parses a CSL style, either independent or dependent, and returns its metadata.
* @param {string} style
* @returns {WasmResult<StyleMeta>}
*/
export function parseStyleMetadata(style: string): WasmResult<StyleMeta>;
interface InitOptions {
/** A CSL style as an XML string */
style: string,
/** A Fetcher implementation for fetching locales.
*
* If not provided, then no locales can be fetched, and default-locale and localeOverride will
* not be respected; the only locale used will be the bundled en-US. */
fetcher?: Fetcher,
/** The output format for this driver instance */
format: "html" | "rtf" | "plain",
/** A locale to use instead of the style's default-locale.
*
* For dependent styles, use parseStyleMetadata to find out which locale it prefers, and pass
* in the parent style with a localeOverride set to that value.
*/
localeOverride?: string,
/** Disables sorting in the bibliography; items appear in cited order. */
bibliographyNoSort?: bool,
}
/** This interface lets citeproc retrieve locales or modules asynchronously,
according to which ones are needed. */
export interface Lifecycle {
export interface Fetcher {
/** Return locale XML for a particular locale. */

@@ -12,2 +41,4 @@ fetchLocale(lang: string): Promise<string>;

export type DateLiteral = { "literal": string; };

@@ -21,2 +52,4 @@ export type DateRaw = { "raw": string; };

/** Locator type, and a locator string */

@@ -29,16 +62,16 @@ export type Locator = {

export type CiteLocator = Locator | { locator: undefined; locators: Locator[] };
export type CiteLocator = Locator | { locator: undefined; locators: Locator[]; };
export type CiteMode = { mode?: "SuppressAuthor" | "AuthorOnly"; };
export type Cite<Affix = string> = {
export type Cite = {
id: string;
prefix?: Affix;
suffix?: Affix;
suppression?: "InText" | "Rest" | null;
} & Partial<CiteLocator>;
prefix?: string;
suffix?: string;
} & Partial<CiteLocator> & CiteMode;
export type ClusterNumber = {
note: number | [number, number]
} | {
inText: number
};
export type ClusterMode
= { mode: "Composite"; infix?: string; suppressFirst?: number; }
| { mode: "SuppressAuthor"; suppressFirst?: number; }
| { mode: "AuthorOnly"; }
| {};

@@ -48,4 +81,8 @@ export type Cluster = {

cites: Cite[];
};
} & ClusterMode;
export type PreviewCluster {
cites: Cite[];
} & ClusterMode;
export type ClusterPosition = {

@@ -57,2 +94,4 @@ id: string;

export type Reference = {

@@ -64,6 +103,8 @@ id: string;

export type CslType = "book" | "article" | "legal_case" | "article-journal";
export type CslType = "book" | "article" | "legal_case" | "article-journal" | string;
export interface BibliographyUpdate {
updatedEntries: { [key: string]: string };
updatedEntries: Map<string, string>;
entryIds?: string[];

@@ -77,19 +118,2 @@ }

type InvalidCsl = {
severity: "Error" | "Warning";
range: {
start: number;
end: number;
};
message: string;
hint: string;
};
type ParseError = {
ParseError: string;
};
type Invalid = {
Invalid: InvalidCsl[];
};
type StyleError = Partial<ParseError & Invalid>;
type IncludeUncited = "None" | "All" | { Specific: string[] };

@@ -105,3 +129,3 @@

type FullRender = {
allClusters: { [clusterId: string]: string },
allClusters: Map<string, string>,
bibEntries: BibEntries,

@@ -111,6 +135,6 @@ };

type BibliographyMeta = {
max_offset: number;
entry_spacing: number;
line_spacing: number;
hanging_indent: boolean;
maxOffset: number;
entrySpacing: number;
lineSpacing: number;
hangingIndent: boolean;
/** the second-field-align value of the CSL style */

@@ -123,2 +147,128 @@ secondFieldAlign: null | "flush" | "margin";

type Severity = "Error" | "Warning";
interface InvalidCsl {
severity: Severity;
/** Relevant bytes in the provided XML */
range: {
start: number,
end: number,
};
message: string;
hint: string | undefined;
};
type StyleError = {
tag: "Invalid",
content: InvalidCsl[],
} | {
tag: "ParseError",
content: string,
} | {
/** Cannot use a dependent style to format citations, pass the parent style instead. */
tag: "DependentStyle",
content: {
requiredParent: string,
}
};
type DriverError = {
tag: "UnknownOutputFormat",
content: string,
} | {
tag: "JsonError",
} | {
tag: "GetFetcherError",
} | {
tag: "NonExistentCluster",
content: string,
} | {
tag: "ReorderingError"
} | {
tag: "ReorderingErrorNumericId"
};
declare global {
/** Catch-all citeproc-rs Error subclass. */
declare class CiteprocRsError extends Error {
constructor(message: string);
}
declare class CiteprocRsDriverError extends CiteprocRsError {
data: DriverError;
constructor(message: string, data: DriverError);
}
declare class CslStyleError extends CiteprocRsError {
data: StyleError;
constructor(message: string, data: StyleError);
}
}
interface WasmResult<T> {
/** If this is an error, throws the error. */
unwrap(): T;
/** If this is an error, returns it, else throws. */
unwrap_err(): Error;
is_ok(): boolean;
is_err(): boolean;
/** If this is an error, returns the default value. */
unwrap_or(default: T): T;
/** If this is Ok, returns f(ok_val), else returns Err unmodified. */
map<R>(f: (t: T) => R): WasmResult<T>;
/** If this is Ok, returns f(ok_val), else returns the default value. */
map_or<R>(default: R, f: (t: T) => R): R;
}
type CitationFormat = "author-date" | "author" | "numeric" | "label" | "note";
interface LocalizedString {
value: string,
lang?: string,
}
interface ParentLink {
href: string,
lang?: string,
}
interface Link {
href: string,
rel: "self" | "documentation" | "template",
lang?: string,
}
interface Rights {
value: string,
lang?: string,
license?: string,
}
interface StyleInfo {
id: string,
updated: string,
title: LocalizedString,
titleShort?: LocalizedString,
parent?: ParentLink,
links: Link[],
rights?: Rights,
citationFormat?: CitationFormat,
categories: string[],
issn?: string,
eissn?: string,
issnl?: string,
}
interface IndependentMeta {
/** A list of languages for which a locale override was specified.
* Does not include the language-less final override. */
localeOverrides: string[],
hasBibliography: bool,
}
interface StyleMeta {
info: StyleInfo,
features: { [feature: string]: bool },
defaultLocale: string,
/** May be absent on a dependent style */
class?: "in-text" | "note",
cslVersionRequired: string,
/** May be absent on a dependent style */
independentMeta?: IndependentMeta,
};
/**

@@ -132,29 +282,30 @@ */

* * `style` is a CSL style as a string. Independent styles only.
* * `lifecycle` must implement the `Lifecycle` interface
* * `fetcher` must implement the `Fetcher` interface
* * `format` is one of { "html", "rtf" }
*
* Throws an error if it cannot parse the style you gave it.
* @param {string} style
* @param {any} lifecycle
* @param {string} format
* @returns {Driver}
* @param {InitOptions} options
* @returns {WasmResult<Driver>}
*/
static new(style: string, lifecycle: any, format: string): Driver;
static new(options: InitOptions): WasmResult<Driver>;
/**
* Sets the style (which will also cause everything to be recomputed)
* @param {string} style_text
* @param {string} style_text
* @returns {WasmResult<undefined>}
*/
setStyle(style_text: string): void;
setStyle(style_text: string): WasmResult<undefined>;
/**
* Completely overwrites the references library.
* This **will** delete references that are not in the provided list.
* @param {any[]} refs
* @param {any[]} refs
* @returns {WasmResult<undefined>}
*/
resetReferences(refs: any[]): void;
resetReferences(refs: any[]): WasmResult<undefined>;
/**
* Inserts or overwrites references as a batch operation.
* This **will not** delete references that are not in the provided list.
* @param {any[]} refs
* @param {any[]} refs
* @returns {WasmResult<undefined>}
*/
insertReferences(refs: any[]): void;
insertReferences(refs: any[]): WasmResult<undefined>;
/**

@@ -164,11 +315,13 @@ * Inserts or overwrites a reference.

* * `refr` is a Reference object.
* @param {Reference} refr
* @param {Reference} refr
* @returns {WasmResult<undefined>}
*/
insertReference(refr: Reference): void;
insertReference(refr: Reference): WasmResult<undefined>;
/**
* Removes a reference by id. If it is cited, any cites will be dangling. It will also
* disappear from the bibliography.
* @param {string} id
* @param {string} id
* @returns {WasmResult<undefined>}
*/
removeReference(id: string): void;
removeReference(id: string): WasmResult<undefined>;
/**

@@ -178,5 +331,6 @@ * Sets the references to be included in the bibliography despite not being directly cited.

* * `refr` is a
* @param {IncludeUncited} uncited
* @param {IncludeUncited} uncited
* @returns {WasmResult<undefined>}
*/
includeUncited(uncited: IncludeUncited): void;
includeUncited(uncited: IncludeUncited): WasmResult<undefined>;
/**

@@ -186,8 +340,8 @@ * Gets a list of locales in use by the references currently loaded.

* Note that Driver comes pre-loaded with the `en-US` locale.
* @returns {any}
* @returns {WasmResult<string[]>}
*/
toFetch(): any;
toFetch(): WasmResult<string[]>;
/**
* Returns a random cluster id, with an extra guarantee that it isn't already in use.
* @returns {string}
* @returns {string}
*/

@@ -197,10 +351,12 @@ randomClusterId(): string;

* Inserts or replaces a cluster with a matching `id`.
* @param {any} cluster
* @param {Cluster} cluster
* @returns {WasmResult<undefined>}
*/
insertCluster(cluster: any): void;
insertCluster(cluster: Cluster): WasmResult<undefined>;
/**
* Removes a cluster with a matching `id`
* @param {string} cluster_id
* @param {string} cluster_id
* @returns {WasmResult<undefined>}
*/
removeCluster(cluster_id: string): void;
removeCluster(cluster_id: string): WasmResult<undefined>;
/**

@@ -210,5 +366,6 @@ * Resets all the clusters in the processor to a new list.

* * `clusters` is a Cluster[]
* @param {any[]} clusters
* @param {any[]} clusters
* @returns {WasmResult<undefined>}
*/
initClusters(clusters: any[]): void;
initClusters(clusters: any[]): WasmResult<undefined>;
/**

@@ -219,6 +376,6 @@ * Returns the formatted citation cluster for `cluster_id`.

* still useful for initialization.
* @param {string} id
* @returns {any}
* @param {string} id
* @returns {WasmResult<string>}
*/
builtCluster(id: string): any;
builtCluster(id: string): WasmResult<string>;
/**

@@ -232,16 +389,16 @@ * Previews a formatted citation cluster, in a particular position.

* any location you can think of.
* @param {any[]} cites
* @param {any[]} positions
* @param {string} format
* @returns {any}
* @param {any[]} cites
* @param {any[]} positions
* @param {string} format
* @returns {WasmResult<string>}
*/
previewCitationCluster(cites: any[], positions: any[], format: string): any;
previewCitationCluster(cites: any[], positions: any[], format: string): WasmResult<string>;
/**
* @returns {BibEntries}
* @returns {WasmResult<BibEntries>}
*/
makeBibliography(): BibEntries;
makeBibliography(): WasmResult<BibEntries>;
/**
* @returns {BibliographyMeta}
* @returns {WasmResult<BibliographyMeta>}
*/
bibliographyMeta(): BibliographyMeta;
bibliographyMeta(): WasmResult<BibliographyMeta>;
/**

@@ -271,5 +428,6 @@ * Specifies which clusters are actually considered to be in the document, and sets their

* May error without having set_cluster_ids, but with some set_cluster_note_number-s executed.
* @param {any[]} positions
* @param {any[]} positions
* @returns {WasmResult<undefined>}
*/
setClusterOrder(positions: any[]): void;
setClusterOrder(positions: any[]): WasmResult<undefined>;
/**

@@ -283,5 +441,5 @@ * Retrieve any clusters that have been touched since last time `batchedUpdates` was

* * returns an `UpdateSummary`
* @returns {UpdateSummary}
* @returns {WasmResult<UpdateSummary>}
*/
batchedUpdates(): UpdateSummary;
batchedUpdates(): WasmResult<UpdateSummary>;
/**

@@ -291,5 +449,5 @@ * Returns all the clusters and bibliography entries in the document.

* Use this to rehydrate a document or run non-interactively.
* @returns {FullRender}
* @returns {WasmResult<FullRender>}
*/
fullRender(): FullRender;
fullRender(): WasmResult<FullRender>;
/**

@@ -301,6 +459,6 @@ * Drains the `batchedUpdates` queue manually.

* Asynchronously fetches all the locales that may be required, and saves them into the
* engine. Uses your provided `Lifecycle.fetchLocale` function.
* @returns {Promise<any>}
* engine. Uses your provided `Fetcher.fetchLocale` function.
* @returns {Promise<any>}
*/
fetchAll(): Promise<any>;
fetchLocales(): Promise<any>;
}

@@ -312,15 +470,16 @@

readonly memory: WebAssembly.Memory;
readonly parseStyleMetadata: (a: number, b: number) => number;
readonly __wbg_driver_free: (a: number) => void;
readonly driver_new: (a: number, b: number, c: number, d: number, e: number) => number;
readonly driver_setStyle: (a: number, b: number, c: number) => void;
readonly driver_resetReferences: (a: number, b: number, c: number) => void;
readonly driver_insertReferences: (a: number, b: number, c: number) => void;
readonly driver_insertReference: (a: number, b: number) => void;
readonly driver_removeReference: (a: number, b: number, c: number) => void;
readonly driver_includeUncited: (a: number, b: number) => void;
readonly driver_new: (a: number) => number;
readonly driver_setStyle: (a: number, b: number, c: number) => number;
readonly driver_resetReferences: (a: number, b: number, c: number) => number;
readonly driver_insertReferences: (a: number, b: number, c: number) => number;
readonly driver_insertReference: (a: number, b: number) => number;
readonly driver_removeReference: (a: number, b: number, c: number) => number;
readonly driver_includeUncited: (a: number, b: number) => number;
readonly driver_toFetch: (a: number) => number;
readonly driver_randomClusterId: (a: number, b: number) => void;
readonly driver_insertCluster: (a: number, b: number) => void;
readonly driver_removeCluster: (a: number, b: number, c: number) => void;
readonly driver_initClusters: (a: number, b: number, c: number) => void;
readonly driver_insertCluster: (a: number, b: number) => number;
readonly driver_removeCluster: (a: number, b: number, c: number) => number;
readonly driver_initClusters: (a: number, b: number, c: number) => number;
readonly driver_builtCluster: (a: number, b: number, c: number) => number;

@@ -330,14 +489,15 @@ readonly driver_previewCitationCluster: (a: number, b: number, c: number, d: number, e: number, f: number, g: number) => number;

readonly driver_bibliographyMeta: (a: number) => number;
readonly driver_setClusterOrder: (a: number, b: number, c: number) => void;
readonly driver_setClusterOrder: (a: number, b: number, c: number) => number;
readonly driver_batchedUpdates: (a: number) => number;
readonly driver_fullRender: (a: number) => number;
readonly driver_drain: (a: number) => void;
readonly driver_fetchAll: (a: number) => number;
readonly driver_fetchLocales: (a: number) => number;
readonly __wbindgen_malloc: (a: number) => number;
readonly __wbindgen_realloc: (a: number, b: number, c: number) => number;
readonly __wbindgen_export_2: WebAssembly.Table;
readonly _dyn_core__ops__function__FnMut__A____Output___R_as_wasm_bindgen__closure__WasmClosure___describe__invoke__hc76d7ca4c06d1374: (a: number, b: number, c: number) => void;
readonly _dyn_core__ops__function__FnMut__A____Output___R_as_wasm_bindgen__closure__WasmClosure___describe__invoke__h2b1b33880a98c55e: (a: number, b: number, c: number) => void;
readonly __wbindgen_add_to_stack_pointer: (a: number) => number;
readonly __wbindgen_free: (a: number, b: number) => void;
readonly __wbindgen_exn_store: (a: number) => void;
readonly wasm_bindgen__convert__closures__invoke2_mut__h982cd7b8d71edcca: (a: number, b: number, c: number, d: number) => void;
readonly wasm_bindgen__convert__closures__invoke2_mut__h4915090d68cfd6bd: (a: number, b: number, c: number, d: number) => void;
}

@@ -354,2 +514,1 @@

export default function init (module_or_path?: InitInput | Promise<InitInput>): Promise<InitOutput>;

@@ -0,1 +1,2 @@

import { WasmResult, CiteprocRsError, CiteprocRsDriverError, CslStyleError } from './snippets/wasm-1883a0b9dcad429e/src/js/include.js';

@@ -117,3 +118,3 @@ let wasm;

function makeMutClosure(arg0, arg1, dtor, f) {
const state = { a: arg0, b: arg1, cnt: 1 };
const state = { a: arg0, b: arg1, cnt: 1, dtor };
const real = (...args) => {

@@ -129,13 +130,30 @@ // First up with a closure we increment the internal reference

} finally {
if (--state.cnt === 0) wasm.__wbindgen_export_2.get(dtor)(a, state.b);
else state.a = a;
if (--state.cnt === 0) {
wasm.__wbindgen_export_2.get(state.dtor)(a, state.b);
} else {
state.a = a;
}
}
};
real.original = state;
return real;
}
function __wbg_adapter_20(arg0, arg1, arg2) {
wasm._dyn_core__ops__function__FnMut__A____Output___R_as_wasm_bindgen__closure__WasmClosure___describe__invoke__hc76d7ca4c06d1374(arg0, arg1, addHeapObject(arg2));
function __wbg_adapter_24(arg0, arg1, arg2) {
wasm._dyn_core__ops__function__FnMut__A____Output___R_as_wasm_bindgen__closure__WasmClosure___describe__invoke__h2b1b33880a98c55e(arg0, arg1, addHeapObject(arg2));
}
/**
* Parses a CSL style, either independent or dependent, and returns its metadata.
* @param {string} style
* @returns {WasmResult<StyleMeta>}
*/
export function parseStyleMetadata(style) {
var ptr0 = passStringToWasm0(style, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
var len0 = WASM_VECTOR_LEN;
var ret = wasm.parseStyleMetadata(ptr0, len0);
return takeObject(ret);
}
let cachegetUint32Memory0 = null;

@@ -169,4 +187,4 @@ function getUint32Memory0() {

}
function __wbg_adapter_66(arg0, arg1, arg2, arg3) {
wasm.wasm_bindgen__convert__closures__invoke2_mut__h982cd7b8d71edcca(arg0, arg1, addHeapObject(arg2), addHeapObject(arg3));
function __wbg_adapter_81(arg0, arg1, arg2, arg3) {
wasm.wasm_bindgen__convert__closures__invoke2_mut__h4915090d68cfd6bd(arg0, arg1, addHeapObject(arg2), addHeapObject(arg3));
}

@@ -188,6 +206,11 @@

free() {
__destroy_into_raw() {
const ptr = this.ptr;
this.ptr = 0;
return ptr;
}
free() {
const ptr = this.__destroy_into_raw();
wasm.__wbg_driver_free(ptr);

@@ -199,18 +222,12 @@ }

* * `style` is a CSL style as a string. Independent styles only.
* * `lifecycle` must implement the `Lifecycle` interface
* * `fetcher` must implement the `Fetcher` interface
* * `format` is one of { "html", "rtf" }
*
* Throws an error if it cannot parse the style you gave it.
* @param {string} style
* @param {any} lifecycle
* @param {string} format
* @returns {Driver}
* @param {InitOptions} options
* @returns {WasmResult<Driver>}
*/
static new(style, lifecycle, format) {
var ptr0 = passStringToWasm0(style, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
var len0 = WASM_VECTOR_LEN;
var ptr1 = passStringToWasm0(format, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);
var len1 = WASM_VECTOR_LEN;
var ret = wasm.driver_new(ptr0, len0, addHeapObject(lifecycle), ptr1, len1);
return Driver.__wrap(ret);
static new(options) {
var ret = wasm.driver_new(addHeapObject(options));
return takeObject(ret);
}

@@ -220,2 +237,3 @@ /**

* @param {string} style_text
* @returns {WasmResult<undefined>}
*/

@@ -225,3 +243,4 @@ setStyle(style_text) {

var len0 = WASM_VECTOR_LEN;
wasm.driver_setStyle(this.ptr, ptr0, len0);
var ret = wasm.driver_setStyle(this.ptr, ptr0, len0);
return takeObject(ret);
}

@@ -232,2 +251,3 @@ /**

* @param {any[]} refs
* @returns {WasmResult<undefined>}
*/

@@ -237,3 +257,4 @@ resetReferences(refs) {

var len0 = WASM_VECTOR_LEN;
wasm.driver_resetReferences(this.ptr, ptr0, len0);
var ret = wasm.driver_resetReferences(this.ptr, ptr0, len0);
return takeObject(ret);
}

@@ -244,2 +265,3 @@ /**

* @param {any[]} refs
* @returns {WasmResult<undefined>}
*/

@@ -249,3 +271,4 @@ insertReferences(refs) {

var len0 = WASM_VECTOR_LEN;
wasm.driver_insertReferences(this.ptr, ptr0, len0);
var ret = wasm.driver_insertReferences(this.ptr, ptr0, len0);
return takeObject(ret);
}

@@ -257,5 +280,7 @@ /**

* @param {Reference} refr
* @returns {WasmResult<undefined>}
*/
insertReference(refr) {
wasm.driver_insertReference(this.ptr, addHeapObject(refr));
var ret = wasm.driver_insertReference(this.ptr, addHeapObject(refr));
return takeObject(ret);
}

@@ -266,2 +291,3 @@ /**

* @param {string} id
* @returns {WasmResult<undefined>}
*/

@@ -271,3 +297,4 @@ removeReference(id) {

var len0 = WASM_VECTOR_LEN;
wasm.driver_removeReference(this.ptr, ptr0, len0);
var ret = wasm.driver_removeReference(this.ptr, ptr0, len0);
return takeObject(ret);
}

@@ -279,5 +306,7 @@ /**

* @param {IncludeUncited} uncited
* @returns {WasmResult<undefined>}
*/
includeUncited(uncited) {
wasm.driver_includeUncited(this.ptr, addHeapObject(uncited));
var ret = wasm.driver_includeUncited(this.ptr, addHeapObject(uncited));
return takeObject(ret);
}

@@ -288,3 +317,3 @@ /**

* Note that Driver comes pre-loaded with the `en-US` locale.
* @returns {any}
* @returns {WasmResult<string[]>}
*/

@@ -301,7 +330,9 @@ toFetch() {

try {
wasm.driver_randomClusterId(8, this.ptr);
var r0 = getInt32Memory0()[8 / 4 + 0];
var r1 = getInt32Memory0()[8 / 4 + 1];
const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);
wasm.driver_randomClusterId(retptr, this.ptr);
var r0 = getInt32Memory0()[retptr / 4 + 0];
var r1 = getInt32Memory0()[retptr / 4 + 1];
return getStringFromWasm0(r0, r1);
} finally {
wasm.__wbindgen_add_to_stack_pointer(16);
wasm.__wbindgen_free(r0, r1);

@@ -312,6 +343,8 @@ }

* Inserts or replaces a cluster with a matching `id`.
* @param {any} cluster
* @param {Cluster} cluster
* @returns {WasmResult<undefined>}
*/
insertCluster(cluster) {
wasm.driver_insertCluster(this.ptr, addHeapObject(cluster));
var ret = wasm.driver_insertCluster(this.ptr, addHeapObject(cluster));
return takeObject(ret);
}

@@ -321,2 +354,3 @@ /**

* @param {string} cluster_id
* @returns {WasmResult<undefined>}
*/

@@ -326,3 +360,4 @@ removeCluster(cluster_id) {

var len0 = WASM_VECTOR_LEN;
wasm.driver_removeCluster(this.ptr, ptr0, len0);
var ret = wasm.driver_removeCluster(this.ptr, ptr0, len0);
return takeObject(ret);
}

@@ -334,2 +369,3 @@ /**

* @param {any[]} clusters
* @returns {WasmResult<undefined>}
*/

@@ -339,3 +375,4 @@ initClusters(clusters) {

var len0 = WASM_VECTOR_LEN;
wasm.driver_initClusters(this.ptr, ptr0, len0);
var ret = wasm.driver_initClusters(this.ptr, ptr0, len0);
return takeObject(ret);
}

@@ -348,3 +385,3 @@ /**

* @param {string} id
* @returns {any}
* @returns {WasmResult<string>}
*/

@@ -368,3 +405,3 @@ builtCluster(id) {

* @param {string} format
* @returns {any}
* @returns {WasmResult<string>}
*/

@@ -382,3 +419,3 @@ previewCitationCluster(cites, positions, format) {

/**
* @returns {BibEntries}
* @returns {WasmResult<BibEntries>}
*/

@@ -390,3 +427,3 @@ makeBibliography() {

/**
* @returns {BibliographyMeta}
* @returns {WasmResult<BibliographyMeta>}
*/

@@ -422,2 +459,3 @@ bibliographyMeta() {

* @param {any[]} positions
* @returns {WasmResult<undefined>}
*/

@@ -427,3 +465,4 @@ setClusterOrder(positions) {

var len0 = WASM_VECTOR_LEN;
wasm.driver_setClusterOrder(this.ptr, ptr0, len0);
var ret = wasm.driver_setClusterOrder(this.ptr, ptr0, len0);
return takeObject(ret);
}

@@ -438,3 +477,3 @@ /**

* * returns an `UpdateSummary`
* @returns {UpdateSummary}
* @returns {WasmResult<UpdateSummary>}
*/

@@ -449,3 +488,3 @@ batchedUpdates() {

* Use this to rehydrate a document or run non-interactively.
* @returns {FullRender}
* @returns {WasmResult<FullRender>}
*/

@@ -464,7 +503,7 @@ fullRender() {

* Asynchronously fetches all the locales that may be required, and saves them into the
* engine. Uses your provided `Lifecycle.fetchLocale` function.
* engine. Uses your provided `Fetcher.fetchLocale` function.
* @returns {Promise<any>}
*/
fetchAll() {
var ret = wasm.driver_fetchAll(this.ptr);
fetchLocales() {
var ret = wasm.driver_fetchLocales(this.ptr);
return takeObject(ret);

@@ -476,3 +515,2 @@ }

if (typeof Response === 'function' && module instanceof Response) {
if (typeof WebAssembly.instantiateStreaming === 'function') {

@@ -496,3 +534,2 @@ try {

} else {
const instance = await WebAssembly.instantiate(module, imports);

@@ -511,3 +548,3 @@

if (typeof input === 'undefined') {
input = import.meta.url.replace(/\.js$/, '_bg.wasm');
input = new URL('citeproc_rs_wasm_bg.wasm', import.meta.url);
}

@@ -522,2 +559,17 @@ const imports = {};

};
imports.wbg.__wbg_debug_4885c3f7d6f044a3 = function(arg0, arg1) {
console.debug(getStringFromWasm0(arg0, arg1));
};
imports.wbg.__wbg_log_bee3ea1a89f334d8 = function(arg0, arg1) {
console.log(getStringFromWasm0(arg0, arg1));
};
imports.wbg.__wbg_info_0547ff9513f2019b = function(arg0, arg1) {
console.info(getStringFromWasm0(arg0, arg1));
};
imports.wbg.__wbg_warn_a478dea6e6e05394 = function(arg0, arg1) {
console.warn(getStringFromWasm0(arg0, arg1));
};
imports.wbg.__wbg_error_72e88ba6901b6eee = function(arg0, arg1) {
console.error(getStringFromWasm0(arg0, arg1));
};
imports.wbg.__wbindgen_json_serialize = function(arg0, arg1) {

@@ -531,14 +583,6 @@ const obj = getObject(arg1);

};
imports.wbg.__wbindgen_json_parse = function(arg0, arg1) {
var ret = JSON.parse(getStringFromWasm0(arg0, arg1));
imports.wbg.__wbindgen_string_new = function(arg0, arg1) {
var ret = getStringFromWasm0(arg0, arg1);
return addHeapObject(ret);
};
imports.wbg.__wbg_fetchLocale_8f52b973b0739a6c = function(arg0, arg1, arg2) {
var ret = getObject(arg0).fetchLocale(getStringFromWasm0(arg1, arg2));
return addHeapObject(ret);
};
imports.wbg.__wbindgen_object_clone_ref = function(arg0) {
var ret = getObject(arg0);
return addHeapObject(ret);
};
imports.wbg.__wbindgen_cb_drop = function(arg0) {

@@ -553,17 +597,51 @@ const obj = takeObject(arg0).original;

};
imports.wbg.__wbg_debug_4885c3f7d6f044a3 = function(arg0, arg1) {
console.debug(getStringFromWasm0(arg0, arg1));
imports.wbg.__wbindgen_json_parse = function(arg0, arg1) {
var ret = JSON.parse(getStringFromWasm0(arg0, arg1));
return addHeapObject(ret);
};
imports.wbg.__wbg_log_bee3ea1a89f334d8 = function(arg0, arg1) {
console.log(getStringFromWasm0(arg0, arg1));
imports.wbg.__wbg_driver_new = function(arg0) {
var ret = Driver.__wrap(arg0);
return addHeapObject(ret);
};
imports.wbg.__wbg_info_0547ff9513f2019b = function(arg0, arg1) {
console.info(getStringFromWasm0(arg0, arg1));
imports.wbg.__wbg_new_f12987d5c30f0ab7 = function(arg0) {
var ret = new CiteprocRsError(takeObject(arg0));
return addHeapObject(ret);
};
imports.wbg.__wbg_warn_a478dea6e6e05394 = function(arg0, arg1) {
console.warn(getStringFromWasm0(arg0, arg1));
imports.wbg.__wbg_new_c5e56e6577bc2b6a = function(arg0, arg1) {
var ret = new CslStyleError(takeObject(arg0), takeObject(arg1));
return addHeapObject(ret);
};
imports.wbg.__wbg_error_72e88ba6901b6eee = function(arg0, arg1) {
console.error(getStringFromWasm0(arg0, arg1));
imports.wbg.__wbg_new_6edca5ab9ee61764 = function(arg0) {
var ret = new WasmResult(takeObject(arg0));
return addHeapObject(ret);
};
imports.wbg.__wbg_get_1edc26456ed84f9b = function(arg0, arg1) {
var ret = getObject(arg0)[takeObject(arg1)];
return addHeapObject(ret);
};
imports.wbg.__wbg_new_8d5f3cd64eaaa8b5 = function(arg0, arg1) {
var ret = new CiteprocRsDriverError(takeObject(arg0), takeObject(arg1));
return addHeapObject(ret);
};
imports.wbg.__wbindgen_object_clone_ref = function(arg0) {
var ret = getObject(arg0);
return addHeapObject(ret);
};
imports.wbg.__wbindgen_is_undefined = function(arg0) {
var ret = getObject(arg0) === undefined;
return ret;
};
imports.wbg.__wbindgen_is_object = function(arg0) {
const val = getObject(arg0);
var ret = typeof(val) === 'object' && val !== null;
return ret;
};
imports.wbg.__wbindgen_is_function = function(arg0) {
var ret = typeof(getObject(arg0)) === 'function';
return ret;
};
imports.wbg.__wbg_fetchLocale_d644d4ae2ca50f81 = function(arg0, arg1, arg2) {
var ret = getObject(arg0).fetchLocale(getStringFromWasm0(arg1, arg2));
return addHeapObject(ret);
};
imports.wbg.__wbg_new_59cb74e423758ede = function() {

@@ -587,11 +665,7 @@ var ret = new Error();

};
imports.wbg.__wbg_new_1d56e97b8de3067f = function(arg0, arg1) {
var ret = new Error(getStringFromWasm0(arg0, arg1));
return addHeapObject(ret);
};
imports.wbg.__wbg_call_0246f1c8ff252fb6 = handleError(function(arg0, arg1, arg2) {
imports.wbg.__wbg_call_f5e0576f61ee7461 = handleError(function(arg0, arg1, arg2) {
var ret = getObject(arg0).call(getObject(arg1), getObject(arg2));
return addHeapObject(ret);
});
imports.wbg.__wbg_new_09f2ad087112acf0 = function(arg0, arg1) {
imports.wbg.__wbg_new_3ea8490cd276c848 = function(arg0, arg1) {
try {

@@ -603,3 +677,3 @@ var state0 = {a: arg0, b: arg1};

try {
return __wbg_adapter_66(a, state0.b, arg0, arg1);
return __wbg_adapter_81(a, state0.b, arg0, arg1);
} finally {

@@ -615,24 +689,14 @@ state0.a = a;

};
imports.wbg.__wbg_resolve_708df7651c8929b8 = function(arg0) {
imports.wbg.__wbg_resolve_778af3f90b8e2b59 = function(arg0) {
var ret = Promise.resolve(getObject(arg0));
return addHeapObject(ret);
};
imports.wbg.__wbg_then_8c23dce80c84c8fb = function(arg0, arg1) {
imports.wbg.__wbg_then_367b3e718069cfb9 = function(arg0, arg1) {
var ret = getObject(arg0).then(getObject(arg1));
return addHeapObject(ret);
};
imports.wbg.__wbg_then_300153bb889a5b4b = function(arg0, arg1, arg2) {
imports.wbg.__wbg_then_ac66ca61394bfd21 = function(arg0, arg1, arg2) {
var ret = getObject(arg0).then(getObject(arg1), getObject(arg2));
return addHeapObject(ret);
};
imports.wbg.__wbindgen_is_undefined = function(arg0) {
var ret = getObject(arg0) === undefined;
return ret;
};
imports.wbg.__wbg_getRandomValues_3ac1b33c90b52596 = function(arg0, arg1, arg2) {
getObject(arg0).getRandomValues(getArrayU8FromWasm0(arg1, arg2));
};
imports.wbg.__wbg_randomFillSync_6f956029658662ec = function(arg0, arg1, arg2) {
getObject(arg0).randomFillSync(getArrayU8FromWasm0(arg1, arg2));
};
imports.wbg.__wbg_self_1c83eb4471d9eb9b = handleError(function() {

@@ -662,2 +726,8 @@ var ret = self.self;

};
imports.wbg.__wbg_getRandomValues_3ac1b33c90b52596 = function(arg0, arg1, arg2) {
getObject(arg0).getRandomValues(getArrayU8FromWasm0(arg1, arg2));
};
imports.wbg.__wbg_randomFillSync_6f956029658662ec = function(arg0, arg1, arg2) {
getObject(arg0).randomFillSync(getArrayU8FromWasm0(arg1, arg2));
};
imports.wbg.__wbindgen_string_get = function(arg0, arg1) {

@@ -674,7 +744,4 @@ const obj = getObject(arg1);

};
imports.wbg.__wbindgen_rethrow = function(arg0) {
throw takeObject(arg0);
};
imports.wbg.__wbindgen_closure_wrapper855 = function(arg0, arg1, arg2) {
var ret = makeMutClosure(arg0, arg1, 186, __wbg_adapter_20);
imports.wbg.__wbindgen_closure_wrapper952 = function(arg0, arg1, arg2) {
var ret = makeMutClosure(arg0, arg1, 227, __wbg_adapter_24);
return addHeapObject(ret);

@@ -687,2 +754,4 @@ };

const { instance, module } = await load(await input, imports);

@@ -689,0 +758,0 @@

@@ -7,3 +7,3 @@ {

"description": "citeproc-rs, compiled to WebAssembly",
"version": "0.0.0-canary-49bfd87",
"version": "0.0.0-canary-502e4f0",
"license": "MPL-2.0",

@@ -19,2 +19,3 @@ "repository": {

"_no_modules/*",
"_zotero/*",
"README.md"

@@ -21,0 +22,0 @@ ],

@@ -49,2 +49,8 @@ # `@citeproc-rs/wasm`

##### Microsoft Edge
Note the caveats in around Microsoft Edge's TextEncoder/TextDecoder support in
[the wasm-bindgen
tutorial](https://rustwasm.github.io/docs/wasm-bindgen/examples/hello-world.html).
#### Using Webpack

@@ -76,12 +82,23 @@

Note the caveats in around Microsoft Edge's TextEncoder/TextDecoder support in
[the wasm-bindgen
tutorial](https://rustwasm.github.io/docs/wasm-bindgen/examples/hello-world.html).
##### React
If you're writing a React app, you may wish to use `React.lazy` like so:
```typescript
// App.tsx
import React, { Suspense } from "react";
const AsyncCiteprocEnabledComponent = React.lazy(async () => {
await import("@citeproc-rs/wasm");
return await import("./CiteprocEnabledComponent");
});
const App = () => (
<Suspense
fallback={<div>Loading citation formatting engine...</div>}>
<AsyncCiteprocEnabledComponent />
</Suspense>
);
// CiteprocEnabledComponent
import { Driver } from "@citeproc-rs/wasm";
function doSomethingWithDriver(driver: Driver) {
// ...
}
// ...
```

@@ -109,10 +126,17 @@

**Careful**: This method does not ensure the package is loaded only once. If
you call init again, it will invalidate any previous Drivers you created.
#### Importing it in a script tag (`no-modules` target)
This replicates the [wasm-bindgen guide
This is *based on* the [wasm-bindgen guide
entry](https://rustwasm.github.io/docs/wasm-bindgen/examples/without-a-bundler.html?highlight=no-modules#using-the-older---target-no-modules),
noting the caveats. You will, similarly to the `web` target, need to make the
contents of the `_no_modules` subdirectory of the published NPM package
available on a webserver or via a CDN.
available on a webserver or via a CDN. But it has **ONE ADDITIONAL FILE** to
import via a script tag.
**Careful**: This method does not ensure the package is loaded only once. If
you call init again, it will invalidate any previous Drivers you created.
```

@@ -124,3 +148,4 @@ <html>

<body>
<!-- Include the JS generated by `wasm-pack build` -->
<!-- Include these TWO JS files -->
<script src='path/to/@citeproc-rs/wasm/_no_modules/citeproc_rs_wasm_include.js'></script>
<script src='path/to/@citeproc-rs/wasm/_no_modules/citeproc_rs_wasm.js'></script>

@@ -154,3 +179,43 @@

#### Usage in Zotero
There is a special build for Zotero and the legacy Firefox ESR extensions API,
which wants a CommonJS module format but without the Node.js `fs` APIs, and
`no-modules`' loading mechanisms but without the use of `window` as a global as
it doesn't exist. The files are in the `_zotero` directory of the NPM package.
Usage is essentially the same as no-modules; you'll need all three files:
* `@citeproc-rs/wasm/_zotero/citeproc_rs_wasm_include.js`
* `@citeproc-rs/wasm/_zotero/citeproc_rs_wasm.js`
* `@citeproc-rs/wasm/_zotero/citeproc_rs_wasm_bg.wasm`
Apart from the CommonJS shims, the main difference is that the API will be
loaded onto the `Zotero.CiteprocRs` object, in order for it all to be linked
together.
**Careful**: This method does not ensure the package is loaded only once. If
you call `initWasmModule` again, it will invalidate any previous Drivers you
created.
```javascript
require("citeproc_rs_wasm_include");
const initWasmModule = require("citeproc_rs_wasm");
const wasmBinaryPromise = Zotero.HTTP
.request('GET',
'resource://zotero/citeproc_rs_wasm_bg.wasm',
{ responseType: "arraybuffer" })
.then(xhr => xhr.response);
await initWasmModule(wasmBinaryPromise);
let driver;
try {
driver = Zotero.CiteprocRs.Driver.new({...}).unwrap();
} catch (e) {
if (e instanceof Zotero.CiteprocRs.CslStyleError) {
// ...
}
}
```
## Usage

@@ -177,3 +242,36 @@

### Error handling
To avoid [this issue][1963], almost every API wraps its return value in a
JavaScript object that contains either a successful result or an error, which
is a JavaScript Error object. This is called `WasmResult`, and it is modelled
on the Rust [`Result` type][rust-result]. If you just want your errors thrown,
simply tack `.unwrap()` onto nearly every API call. If you want to handle them
manually, you can, and this is mainly useful for showing style parse or
validation errors. Some error types have structured data attached to them.
```typescript
let result = Driver.new({ ... });
if (result.is_err()) {
let error = result.unwrap_err();
if (error instanceof CslStyleError) {
console.warn("Could not parse CSL, error:", error);
// You can also
// throw error;
}
} else {
let driver = result.unwrap();
}
// ...
driver.free(); // No unwrap.
```
The error types must unfortunately be global exports, on window/global/self.
In this document, `.unwrap()` used after an example means it returns a
WasmResult.
[1963]: https://github.com/rustwasm/wasm-bindgen/issues/1963
[rust-result]: https://doc.rust-lang.org/stable/std/result/enum.Result.html
### 1. Creating a driver instance

@@ -186,7 +284,21 @@

A driver needs an XML style string, a fetcher (below), and an output format
(one of `"html"`, `"rtf"` or `"plain"`).
A driver needs at least an XML style string, a fetcher (below), and an output
format (one of `"html"`, `"rtf"` or `"plain"`).
```javascript
let driver = Driver.new(cslStyleTextAsXML, fetcher, "html");
let fetcher = ...; // see below
let driverResult = Driver.new({
style: "<style version=\"1.0\" class=\"note\" ... > ... </style>",
format: "html", // optional, html is the default
formatOptions: { // optional
linkAnchors: true, // optional, default true
},
localeOverride: "de-DE", // optional, like setting default-locale on the style
// bibliographyNoSort: true // disables sorting on the bibliography
fetcher,
});
// Throw any errors, get the inner Driver
let driver = driverResult.unwrap();
// Fetch the chain of locale files required to use the specified locale
await driver.fetchLocales();
// ... use the driver ...

@@ -197,13 +309,12 @@ driver.free()

The library parses and validates the CSL style input. Any validation errors are
reported, with line/column positions, the text at that location, a descriptive
and useful message (only in English at the moment) and sometimes even a hint
for how to fix it. This is thrown as an error, which you can catch in a `try {}
catch (e) {}` block.
reported, with byte offsets to find the CSL fragment responsible, a descriptive
and useful message (in English) and sometimes even a hint for how to fix it.
See [Error Handling](#error-handling) for how to access this.
#### Fetcher
There are hundreds of locales, and the locales you need change depending on the
references that are active in your document, so the procedure for retrieving
one is asynchronous to allow for fetching one over HTTP. There's not much more
to it than this:
There are hundreds of locales, and the locales you need depend on the style
default, any overrides and any fallback locales defined, so the procedure for
retrieving one is asynchronous to allow for fetching one over HTTP. There's not
much more to it than this:

@@ -213,3 +324,3 @@ ```javascript

async fetchLocale(lang) {
return fetch("https://some-cdn-with-locales.com/locales-${lang}.xml")
return await fetch("https://some-cdn-with-locales.com/locales-${lang}.xml")
.then(res => res.text());

@@ -226,3 +337,6 @@

let fetcher = new Fetcher(); // Pass to Driver.new()
let fetcher = new Fetcher();
let driver = Driver.new({ ..., fetcher }).unwrap();
// Make sure you actually fetch them!
await driver.fetchLocales();
```

@@ -233,5 +347,8 @@

Declining to provide a locale fetcher in `Driver.new` or forgetting to call
`await driver.fetchLocales()` results in use of the bundled `en-US` locale. You
should also never attempt to use the driver instance while it is fetching locales.
### 2. Edit the references or the citation clusters
#### References

@@ -244,17 +361,8 @@

```javascript
driver.insertReference({ id: "citekey", type: "book", title: "Title" });
driver.insertReferences([ ... many references ... ]);
driver.resetReferences([ ... deletes any others ... ]);
driver.removeReference("citekey");
driver.insertReference({ id: "citekey", type: "book", title: "Title" }).unwrap();
driver.insertReferences([ ... many references ... ]).unwrap();
driver.resetReferences([ ... deletes any others ... ]).unwrap();
driver.removeReference("citekey").unwrap();
```
When you do insert a reference, it may have locale information in it. This
should be done after updating the references, so any new locales can be
fetched.
```javascript
// May call your Fetcher instance.
await driver.fetchAll();
```
#### Citation Clusters and their Cites

@@ -270,8 +378,8 @@

{ id: "two", cites: [ {id: "citekey", locator: "56", label: "page" } ] },
]);
]).unwrap();
// Update or insert any one of them like so
driver.insertCluster({ id: "one", cites: [ { id: "updated_citekey" } ] });
driver.insertCluster({ id: "one", cites: [ { id: "updated_citekey" } ] }).unwrap();
// (You can use `driver.randomClusterId()` to generate a new one at random.)
let three = driver.randomClusterId();
driver.insertCluster({ id: three, cites: [ { id: "new_cluster_here" } ] });
driver.insertCluster({ id: three, cites: [ { id: "new_cluster_here" } ] }).unwrap();
```

@@ -290,3 +398,3 @@

```javascript
driver.setClusterOrder([ { id: "one", note: 1 }, { id: "two", note: 4 } ]);
driver.setClusterOrder([ { id: "one", note: 1 }, { id: "two", note: 4 } ]).unwrap();
```

@@ -306,5 +414,5 @@

```javascript
driver.includeUncited("None"); // Default
driver.includeUncited("All");
driver.includeUncited({ Specific: ["citekeyA", "citekeyB"] });
driver.includeUncited("None").unwrap(); // Default
driver.includeUncited("All").unwrap();
driver.includeUncited({ Specific: ["citekeyA", "citekeyB"] }).unwrap();
```

@@ -327,5 +435,8 @@

// Get the diff since last time batchedUpdates, fullRender or drain was called.
let diff = driver.batchedUpdates();
let diff = driver.batchedUpdates().unwrap();
// apply cluster changes to the UI.
// ("myDocument" is an imaginary API.)
for (let changedCluster of diff.clusters) {

@@ -364,6 +475,6 @@ let [id, html] = changedCluster;

// lay out the bibliography. There is a similar API in citeproc-js.
let meta = driver.bibliographyMeta();
let meta = driver.bibliographyMeta().unwrap();
// This is an array of BibEntry
let bibliography = driver.makeBibliography();
let bibliography = driver.makeBibliography().unwrap();
for (let entry of bibliography) {

@@ -382,5 +493,9 @@ console.log(entry.id, entry.value);

let positions = [ ... before, { note: 34 }, ... after ];
let preview = driver.previewCitationCluster(cites, positions, "html");
let preview = driver.previewCitationCluster(cites, positions, "html").unwrap();
```
The format argument is like the format passed to `Driver.new`: one of `"html"`,
`"rtf"` or `"plain"`. The driver will use that instead of its normal output
format.
The positions array is exactly like a call to `setClusterOrder`, except exactly

@@ -399,3 +514,59 @@ one of the positions omits the id field. This could either:

### `AuthorOnly`, `SuppressAuthor` & `Composite`
`@citeproc-rs/wasm` supports these flags on clusters (all 3) and cites (except
`Composite`), in a similar way to `citeproc-js`. See the [`citeproc-js`
documentation on Special Citation
Forms](https://citeproc-js.readthedocs.io/en/latest/running.html#special-citation-forms)
for reference.
```javascript
// only two modes for cites
let citeAO = { id: "jones2006", mode: "AuthorOnly" };
let citeSA = { id: "jones2006", mode: "SuppressAuthor" };
// additional options for clusters
let clusterAO = { id: "one", cites: [...], mode: "AuthorOnly" };
let clusterSA = { id: "one", cites: [...], mode: "SuppressAuthor" };
let clusterSA_First = { id: "one", cites: [...], mode: "SuppressAuthor", suppressFirst: 3 };
let clusterC = { id: "one", cites: [...], mode: "Composite" };
let clusterC_Infix = { id: "one", cites: [...], mode: "Composite", infix: ", whose book" };
let clusterC_Full = { id: "one", cites: [...], mode: "Composite", infix: ", whose books", suppressFirst: 0 };
```
It does support one extra option with `SuppressAuthor` and `Composite` on
clusters: `suppressFirst`, which limits the effect to the first N name groups
(or if cite grouping is disabled, first N names). Setting it to 0 means
unlimited.
#### `<intext>` element with `AuthorOnly` etc.
`citeproc-rs` supports the `<intext>` element described in the `citeproc-js`
docs linked above, but it is not enabled by default. It also supports `<intext
and="symbol">` or `and="text"`, which will swap out the last intext layout
delimiter (`<layout delimiter="; ">`) for either the ampersand or the `and`
term.
If you want to use the `<intext>` element in CSL, you may either:
##### Option 1: Add a feature flag to the style wishing to use it
```xml
<style class="in-text">
<features>
<feature name="custom-intext" />
</features>
...
</style>
```
AFAIK no other processors support this syntax yet.
##### Option 2: Enable the `custom-intext` feature for all styles via `Driver.new`
```javascript
let driver = Driver.new({ ..., cslFeatures: ["custom-intext"] }).unwrap();
// ... driver.free();
```
### Non-Interactive use, or re-hydrating a previously created document

@@ -416,5 +587,5 @@

// document's clusters
driver.resetReferences(myDocument.allReferences);
driver.initClusters(allNotes.map(fn => fn.cluster));
driver.setClusterOrder(allNotes.map(fn => { id: fn.cluster.id, note: fn.number }));
driver.resetReferences(myDocument.allReferences).unwrap();
driver.initClusters(allNotes.map(fn => fn.cluster)).unwrap();
driver.setClusterOrder(allNotes.map(fn => { id: fn.cluster.id, note: fn.number })).unwrap();

@@ -424,3 +595,3 @@ // Render every cluster and bibliography item.

// see the FullRender typescript type
let render = driver.fullRender();
let render = driver.fullRender().unwrap();

@@ -442,1 +613,50 @@ // Write out the rendered clusters into the doc

### `parseStyleMetadata`
Sometimes you want information about a CSL style without actually booting up a
whole driver. One important use case is a dependent style, which can't be used
with `Driver.new()` because it doesn't have the ability to render citations on
its own, and is essentially just a container for three pieces of information:
- A journal name
- An independent parent style
- A possible default-locale override
`@citeproc-rs/wasm` provides an API for finding out what's in a CSL style file.
```typescript
let result = parseStyleMetadata("<style ...> ... </style>").unwrap();
```
The result could be a `CslStyleError`, but this is less likely than with
Driver.new() as it will not actually attempt to parse and validate all the
parts of a style.
Here's how to use `parseStyleMetadata` to parse and use a dependent style.
```typescript
let dependentStyle = "<style ...> ... </style>";
let meta = parseStyleMetadata(dependentStyle).unwrap();
let isDependent = meta.info.parent != null;
let parentStyleId = isDependent && meta.info.parent.href;
let localeOverride = meta.defaultLocale;
// ...
let parentStyle = await downloadStyleWithId(parentStyleId);
let driver = Driver.new({
style: parentStyle,
localeOverride,
...
}).unwrap();
await driver.fetchLocales();
// Here you might also want to know if the style can render a bibliography or not
let parentMeta = parseStyleMetadata(parentStyle).unwrap();
if (parentMeta.independentMeta.hasBibliography) {
let bib = driver.makeBibliography().unwrap();
// ...
}
// ...
driver.free();
```

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc