/** * Creates a function that performs a deep comparison between a given target and the source object. * * @param {unknown} source - The source object to create the matcher from. * @returns {(target: unknown) => boolean} - Returns a function that takes a target object and returns `true` if the target matches the source, otherwise `false`. * * @example * // Basic usage * const matcher = matches({ a: 1, b: 2 }); * matcher({ a: 1, b: 2, c: 3 }); // true * matcher({ a: 1, c: 3 }); // false * * @example * // Matching arrays * const arrayMatcher = matches([1, 2, 3]); * arrayMatcher([1, 2, 3, 4]); // true * arrayMatcher([4, 5, 6]); // false * * @example * // Matching objects with nested structures * const nestedMatcher = matches({ a: { b: 2 } }); * nestedMatcher({ a: { b: 2, c: 3 } }); // true * nestedMatcher({ a: { c: 3 } }); // false */ declare function matches(source: unknown): (target: unknown) => boolean; export { matches };