[API reference](https://evolu.dev/docs/api-reference) › [@evolu/common](https://evolu.dev/docs/api-reference/common) › [Set](https://evolu.dev/docs/api-reference/common/Set) › isNonEmptySet

```ts
function isNonEmptySet<T>(set: ReadonlySet<T>): set is NonEmptyReadonlySet<T>;
```

Defined in: [packages/common/src/Set.ts:108](https://github.com/evoluhq/evolu/blob/e7144e2bbe9069362b62dec1b64a8aa922b8f1b0/packages/common/src/Set.ts#L108)

Checks if a set is non-empty and narrows its type to
[NonEmptyReadonlySet](https://evolu.dev/docs/api-reference/common/Set/type-aliases/NonEmptyReadonlySet).

Both mutable and readonly sets narrow to the branded
[NonEmptyReadonlySet](https://evolu.dev/docs/api-reference/common/Set/type-aliases/NonEmptyReadonlySet) type, which can be used with functions like
[firstInSet](https://evolu.dev/docs/api-reference/common/Set/functions/firstInSet).

To check if a set is empty, use `if (!isNonEmptySet(set))` — using the
negated guard is better than `.size === 0` for early returns because
TypeScript narrows the type after the check.

### Example

```ts
const set: ReadonlySet<number> = new Set([1, 2, 3]);
if (isNonEmptySet(set)) {
  firstInSet(set); // set is NonEmptyReadonlySet<number>
}
```