1
0
mirror of https://github.com/redis/node-redis.git synced 2025-08-03 04:01:40 +03:00
Files
node-redis/packages/client/lib/commands/SINTERCARD.ts
Bobby I. 20c16e0c2c (docs) add jsdoc comments to command parsers (#2984)
* (docs) bloom: add jsdocs for all commands

* (docs) json: add jsdocs

* (docs) search: add jsdocs for all commands

* (docs) jsdocs for std commands

* (docs) jsdoc comments to time series commands
2025-06-03 14:38:07 +03:00

36 lines
1.2 KiB
TypeScript

import { CommandParser } from '../client/parser';
import { NumberReply, Command } from '../RESP/types';
import { RedisVariadicArgument } from './generic-transformers';
/**
* Options for the SINTERCARD command
*
* @property LIMIT - Maximum number of elements to return
*/
export interface SInterCardOptions {
LIMIT?: number;
}
export default {
IS_READ_ONLY: true,
/**
* Constructs the SINTERCARD command
*
* @param parser - The command parser
* @param keys - One or more set keys to compute the intersection cardinality from
* @param options - Options for the SINTERCARD command or a number for LIMIT (backwards compatibility)
* @see https://redis.io/commands/sintercard/
*/
parseCommand(parser: CommandParser, keys: RedisVariadicArgument, options?: SInterCardOptions | number) {
parser.push('SINTERCARD');
parser.pushKeysLength(keys);
if (typeof options === 'number') { // backwards compatibility
parser.push('LIMIT', options.toString());
} else if (options?.LIMIT !== undefined) {
parser.push('LIMIT', options.LIMIT.toString());
}
},
transformReply: undefined as unknown as () => NumberReply
} as const satisfies Command;