music-metadata
Version:
Music metadata parser for Node.js, supporting virtual any audio and tag format.
47 lines (46 loc) • 1.76 kB
TypeScript
import * as strtok3 from 'strtok3';
import type { IOptions, IApeHeader } from '../type.js';
import type { INativeMetadataCollector } from '../common/MetadataCollector.js';
import { BasicParser } from '../common/BasicParser.js';
import { type IFooter, type IHeader } from './APEv2Token.js';
import type { IRandomAccessTokenizer } from 'strtok3';
declare const ApeContentError_base: {
new (message: string): {
readonly fileType: string;
toString(): string;
name: "UnexpectedFileContentError";
message: string;
stack?: string;
};
captureStackTrace(targetObject: object, constructorOpt?: Function): void;
prepareStackTrace(err: Error, stackTraces: NodeJS.CallSite[]): any;
stackTraceLimit: number;
};
export declare class ApeContentError extends ApeContentError_base {
}
export declare function tryParseApeHeader(metadata: INativeMetadataCollector, tokenizer: strtok3.ITokenizer, options: IOptions): Promise<void>;
export declare class APEv2Parser extends BasicParser {
/**
* Calculate the media file duration
* @param ah ApeHeader
* @return {number} duration in seconds
*/
static calculateDuration(ah: IHeader): number;
/**
* Calculates the APEv1 / APEv2 first field offset
* @param tokenizer
* @param offset
*/
static findApeFooterOffset(tokenizer: IRandomAccessTokenizer, offset: number): Promise<IApeHeader | undefined>;
private static parseTagFooter;
private ape;
/**
* Parse APEv1 / APEv2 header if header signature found
*/
tryParseApeHeader(): Promise<void>;
parse(): Promise<void>;
parseTags(footer: IFooter): Promise<void>;
private parseDescriptorExpansion;
private parseHeader;
}
export {};