Commit bc19ec8
committed
vfs: fix bugs from analysis review
P0 fixes:
- setup.js: use fileURLToPath() instead of path.pathname for file: URLs
- file_handle.js: enforce read/write permissions and exclusive flags
- memory.js: prevent auto-creation of parent dirs in openSync
- memory.js: validate destination before removing source in renameSync
P1 fixes:
- memory.js: convert numeric O_* flags to string equivalents
- dir.js: add callback support to read() and close()
- watcher.js: fix unwatchFile leak by clearing internal listeners set
- provider.js: pass options.flag through writeFile/appendFile
- memory.js: implement recursive readdir
- watcher.js: poll children for directory watch, rescan for new files
- streams.js: support fd and start options in read/write streams
P2 fixes:
- provider.js: check R_OK/W_OK/X_OK permission bits in access()
- provider.js: check COPYFILE_EXCL in copyFile()
- stats.js: add createZeroStats() without S_IFREG for watchFile
- errors.js: add createEACCES error factory1 parent d96bc30 commit bc19ec8
10 files changed
Lines changed: 510 additions & 104 deletions
File tree
- lib/internal/vfs
- providers
- test/parallel
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
42 | 42 | | |
43 | 43 | | |
44 | 44 | | |
45 | | - | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
46 | 55 | | |
47 | 56 | | |
48 | 57 | | |
49 | 58 | | |
50 | 59 | | |
51 | 60 | | |
52 | 61 | | |
53 | | - | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
54 | 68 | | |
55 | 69 | | |
56 | 70 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
18 | 18 | | |
19 | 19 | | |
20 | 20 | | |
| 21 | + | |
21 | 22 | | |
22 | 23 | | |
23 | 24 | | |
| |||
162 | 163 | | |
163 | 164 | | |
164 | 165 | | |
| 166 | + | |
| 167 | + | |
| 168 | + | |
| 169 | + | |
| 170 | + | |
| 171 | + | |
| 172 | + | |
| 173 | + | |
| 174 | + | |
| 175 | + | |
| 176 | + | |
| 177 | + | |
| 178 | + | |
| 179 | + | |
| 180 | + | |
| 181 | + | |
165 | 182 | | |
166 | 183 | | |
167 | 184 | | |
| |||
172 | 189 | | |
173 | 190 | | |
174 | 191 | | |
| 192 | + | |
175 | 193 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
277 | 277 | | |
278 | 278 | | |
279 | 279 | | |
280 | | - | |
| 280 | + | |
| 281 | + | |
281 | 282 | | |
282 | 283 | | |
283 | 284 | | |
284 | 285 | | |
285 | 286 | | |
286 | | - | |
| 287 | + | |
| 288 | + | |
287 | 289 | | |
288 | 290 | | |
289 | 291 | | |
290 | 292 | | |
291 | 293 | | |
| 294 | + | |
| 295 | + | |
| 296 | + | |
| 297 | + | |
| 298 | + | |
| 299 | + | |
| 300 | + | |
| 301 | + | |
| 302 | + | |
| 303 | + | |
| 304 | + | |
| 305 | + | |
| 306 | + | |
| 307 | + | |
| 308 | + | |
| 309 | + | |
| 310 | + | |
| 311 | + | |
| 312 | + | |
| 313 | + | |
| 314 | + | |
| 315 | + | |
| 316 | + | |
| 317 | + | |
| 318 | + | |
| 319 | + | |
| 320 | + | |
| 321 | + | |
292 | 322 | | |
293 | 323 | | |
294 | 324 | | |
| |||
325 | 355 | | |
326 | 356 | | |
327 | 357 | | |
| 358 | + | |
328 | 359 | | |
329 | 360 | | |
330 | 361 | | |
| |||
369 | 400 | | |
370 | 401 | | |
371 | 402 | | |
| 403 | + | |
372 | 404 | | |
373 | | - | |
| 405 | + | |
| 406 | + | |
| 407 | + | |
| 408 | + | |
374 | 409 | | |
375 | 410 | | |
376 | 411 | | |
| |||
417 | 452 | | |
418 | 453 | | |
419 | 454 | | |
| 455 | + | |
420 | 456 | | |
421 | 457 | | |
422 | 458 | | |
| |||
434 | 470 | | |
435 | 471 | | |
436 | 472 | | |
| 473 | + | |
437 | 474 | | |
438 | 475 | | |
439 | 476 | | |
| |||
452 | 489 | | |
453 | 490 | | |
454 | 491 | | |
| 492 | + | |
455 | 493 | | |
456 | 494 | | |
457 | 495 | | |
| |||
512 | 550 | | |
513 | 551 | | |
514 | 552 | | |
| 553 | + | |
515 | 554 | | |
516 | 555 | | |
517 | 556 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
6 | 6 | | |
7 | 7 | | |
8 | 8 | | |
| 9 | + | |
| 10 | + | |
9 | 11 | | |
10 | 12 | | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
11 | 22 | | |
12 | 23 | | |
13 | 24 | | |
| |||
267 | 278 | | |
268 | 279 | | |
269 | 280 | | |
270 | | - | |
| 281 | + | |
| 282 | + | |
271 | 283 | | |
272 | 284 | | |
273 | 285 | | |
| |||
285 | 297 | | |
286 | 298 | | |
287 | 299 | | |
288 | | - | |
| 300 | + | |
| 301 | + | |
289 | 302 | | |
290 | 303 | | |
291 | 304 | | |
| |||
304 | 317 | | |
305 | 318 | | |
306 | 319 | | |
307 | | - | |
| 320 | + | |
| 321 | + | |
308 | 322 | | |
309 | 323 | | |
310 | 324 | | |
| |||
322 | 336 | | |
323 | 337 | | |
324 | 338 | | |
325 | | - | |
| 339 | + | |
| 340 | + | |
326 | 341 | | |
327 | 342 | | |
328 | 343 | | |
| |||
369 | 384 | | |
370 | 385 | | |
371 | 386 | | |
| 387 | + | |
| 388 | + | |
| 389 | + | |
| 390 | + | |
| 391 | + | |
372 | 392 | | |
373 | 393 | | |
374 | 394 | | |
| |||
383 | 403 | | |
384 | 404 | | |
385 | 405 | | |
| 406 | + | |
| 407 | + | |
| 408 | + | |
| 409 | + | |
| 410 | + | |
386 | 411 | | |
387 | 412 | | |
388 | 413 | | |
| |||
420 | 445 | | |
421 | 446 | | |
422 | 447 | | |
423 | | - | |
424 | | - | |
| 448 | + | |
| 449 | + | |
425 | 450 | | |
426 | 451 | | |
427 | 452 | | |
| |||
430 | 455 | | |
431 | 456 | | |
432 | 457 | | |
433 | | - | |
434 | | - | |
| 458 | + | |
| 459 | + | |
| 460 | + | |
| 461 | + | |
| 462 | + | |
| 463 | + | |
| 464 | + | |
| 465 | + | |
| 466 | + | |
| 467 | + | |
| 468 | + | |
| 469 | + | |
| 470 | + | |
| 471 | + | |
| 472 | + | |
| 473 | + | |
| 474 | + | |
| 475 | + | |
| 476 | + | |
| 477 | + | |
| 478 | + | |
| 479 | + | |
| 480 | + | |
| 481 | + | |
435 | 482 | | |
436 | 483 | | |
437 | 484 | | |
| |||
0 commit comments