import { Obj } from './types'; /** * Return a new object by adding missing keys into another object */ export declare function applyDefaults(hash: any, defaults: any): any; /** * Return whether the given parameter is an empty object or empty list. */ export declare function isEmpty(x: any): boolean; /** * Deep clone a tree of objects, lists or scalars * * Does not support cycles. */ export declare function deepClone(x: any): any; /** * Map over an object, treating it as a dictionary */ export declare function mapObject(x: Obj, fn: (key: string, value: T) => U): U[]; /** * Construct an object from a list of (k, v) pairs */ export declare function makeObject(pairs: Array<[string, T]>): Obj; /** * Deep get a value from a tree of nested objects * * Returns undefined if any part of the path was unset or * not an object. */ export declare function deepGet(x: any, path: string[]): any; /** * Deep set a value in a tree of nested objects * * Throws an error if any part of the path is not an object. */ export declare function deepSet(x: any, path: string[], value: any): void; /** * Recursively merge objects together * * The leftmost object is mutated and returned. Arrays are not merged * but overwritten just like scalars. * * If an object is merged into a non-object, the non-object is lost. */ export declare function deepMerge(...objects: Array | undefined>): Obj; /** * Splits the given object into two, such that: * * 1. The size of the first object (after stringified in UTF-8) is less than or equal to the provided size limit. * 2. Merging the two objects results in the original one. */ export declare function splitBySize(data: any, maxSizeBytes: number): [any, any];