In CM7, how NVIC distinguishes pulse and level interrupts?

Apologizing for a naïve question... but I cannot figure out from this description, how the NVIC knows is a particular interrupt input level or pulse?

https://developer.arm.com/documentation/ddi0489/d/nested-vectored-interrupt-controller/nvic-functional-description/level-versus-pulse-interrupts

From the description, it looks like the NVIC detects only the level and latches the request.

Then, if the NVIC input goes low before handling of the request completes, it is considered "pulse" (either it goes low by itself, or the handler clears it).

If the line still is high, the request is re-latched and the loop continues.

Is this correct, or are there other documents to clarify this?