/// import * as stream from "stream"; export = stringify declare function stringify(callback?: stringify.Callback): stringify.Stringifier declare function stringify(options: stringify.Options, callback?: stringify.Callback): stringify.Stringifier declare function stringify(input: stringify.Input, callback?: stringify.Callback): stringify.Stringifier declare function stringify(input: stringify.Input, options?: stringify.Options, callback?: stringify.Callback): stringify.Stringifier declare namespace stringify { type Callback = (err: Error | undefined, output: string) => void type RecordDelimiter = string | Buffer | 'auto' | 'unix' | 'mac' | 'windows' | 'ascii' | 'unicode' type Cast = (value: T, context: CastingContext) => string type PlainObject = Record type Input = any[] interface ColumnOption { key: string header?: string } interface CastingContext { readonly column?: number | string; readonly header: boolean; readonly index: number; readonly records: number; } interface Options { /** * Prepend the byte order mark (BOM) to the output stream. */ bom?: boolean /** * Key-value object which defines custom cast for certain data types */ cast?: { boolean?: Cast date?: Cast number?: Cast /** * Custom formatter for generic object values */ object?: Cast> string?: Cast } /** * List of fields, applied when `transform` returns an object * order matters * read the transformer documentation for additionnal information * columns are auto discovered in the first record when the user write objects * can refer to nested properties of the input JSON * see the "header" option on how to print columns names on the first line */ columns?: string[] | PlainObject | ColumnOption[] /** * Set the field delimiter, one character only, defaults to a comma. */ delimiter?: string | Buffer /** * Add the value of "options.RecordDelimiter" on the last line, default to true. */ eof?: boolean /** * Defaults to the escape read option. */ escape?: string | Buffer /** * Display the column names on the first line if the columns option is provided or discovered. */ header?: boolean /** * The quote characters, defaults to the ", an empty quote value will preserve the original field. */ quote?: string | Buffer | boolean /** * Boolean, default to false, quote all the non-empty fields even if not required. */ quoted?: boolean /** * Boolean, no default, quote empty fields and overrides `quoted_string` on empty strings when defined. */ quoted_empty?: boolean /** * String or RegExp, no default, quote all fields matching a regular expression. */ quoted_match?: string | RegExp /** * Boolean, default to false, quote all fields of type string even if not required. */ quoted_string?: boolean /** * String used to delimit record rows or a special value * special values are 'auto', 'unix', 'mac', 'windows', 'ascii', 'unicode' * defaults to 'auto' (discovered in source or 'unix' if no source is specified). */ record_delimiter?: RecordDelimiter } class Stringifier extends stream.Transform { constructor(options: Options) readonly options: Options } }