gx
chenyc
2025-06-12 7b72ac13a83764a662159d4a49b7fffb90476ecb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
// this is the only approach that was significantly faster than using
// str.replace(/\/+$/, '') for strings ending with a lot of / chars and
// containing multiple / chars.
const batchStrings = [
  '/'.repeat(1024),
  '/'.repeat(512),
  '/'.repeat(256),
  '/'.repeat(128),
  '/'.repeat(64),
  '/'.repeat(32),
  '/'.repeat(16),
  '/'.repeat(8),
  '/'.repeat(4),
  '/'.repeat(2),
  '/',
]
 
module.exports = str => {
  for (const s of batchStrings) {
    while (str.length >= s.length && str.slice(-1 * s.length) === s)
      str = str.slice(0, -1 * s.length)
  }
  return str
}