Spaces:
Sleeping
Sleeping
Shreyan
commited on
Commit
·
7f21468
0
Parent(s):
Clean initial commit without large files
Browse filesThis view is limited to 50 files because it contains too many changes.
See raw diff
- .gitignore +26 -0
- CleanedJobs.ipynb +1165 -0
- README.md +52 -0
- model.py +108 -0
- node_modules/.bin/gh-pages +16 -0
- node_modules/.bin/gh-pages-clean +16 -0
- node_modules/.bin/gh-pages-clean.cmd +17 -0
- node_modules/.bin/gh-pages-clean.ps1 +28 -0
- node_modules/.bin/gh-pages.cmd +17 -0
- node_modules/.bin/gh-pages.ps1 +28 -0
- node_modules/.bin/semver +16 -0
- node_modules/.bin/semver.cmd +17 -0
- node_modules/.bin/semver.ps1 +28 -0
- node_modules/.package-lock.json +620 -0
- node_modules/@nodelib/fs.scandir/LICENSE +21 -0
- node_modules/@nodelib/fs.scandir/README.md +171 -0
- node_modules/@nodelib/fs.scandir/out/adapters/fs.d.ts +20 -0
- node_modules/@nodelib/fs.scandir/out/adapters/fs.js +19 -0
- node_modules/@nodelib/fs.scandir/out/constants.d.ts +4 -0
- node_modules/@nodelib/fs.scandir/out/constants.js +17 -0
- node_modules/@nodelib/fs.scandir/out/index.d.ts +12 -0
- node_modules/@nodelib/fs.scandir/out/index.js +26 -0
- node_modules/@nodelib/fs.scandir/out/providers/async.d.ts +7 -0
- node_modules/@nodelib/fs.scandir/out/providers/async.js +104 -0
- node_modules/@nodelib/fs.scandir/out/providers/common.d.ts +1 -0
- node_modules/@nodelib/fs.scandir/out/providers/common.js +13 -0
- node_modules/@nodelib/fs.scandir/out/providers/sync.d.ts +5 -0
- node_modules/@nodelib/fs.scandir/out/providers/sync.js +54 -0
- node_modules/@nodelib/fs.scandir/out/settings.d.ts +20 -0
- node_modules/@nodelib/fs.scandir/out/settings.js +24 -0
- node_modules/@nodelib/fs.scandir/out/types/index.d.ts +20 -0
- node_modules/@nodelib/fs.scandir/out/types/index.js +2 -0
- node_modules/@nodelib/fs.scandir/out/utils/fs.d.ts +2 -0
- node_modules/@nodelib/fs.scandir/out/utils/fs.js +19 -0
- node_modules/@nodelib/fs.scandir/out/utils/index.d.ts +2 -0
- node_modules/@nodelib/fs.scandir/out/utils/index.js +5 -0
- node_modules/@nodelib/fs.scandir/package.json +44 -0
- node_modules/@nodelib/fs.stat/LICENSE +21 -0
- node_modules/@nodelib/fs.stat/README.md +126 -0
- node_modules/@nodelib/fs.stat/out/adapters/fs.d.ts +13 -0
- node_modules/@nodelib/fs.stat/out/adapters/fs.js +17 -0
- node_modules/@nodelib/fs.stat/out/index.d.ts +12 -0
- node_modules/@nodelib/fs.stat/out/index.js +26 -0
- node_modules/@nodelib/fs.stat/out/providers/async.d.ts +4 -0
- node_modules/@nodelib/fs.stat/out/providers/async.js +36 -0
- node_modules/@nodelib/fs.stat/out/providers/sync.d.ts +3 -0
- node_modules/@nodelib/fs.stat/out/providers/sync.js +23 -0
- node_modules/@nodelib/fs.stat/out/settings.d.ts +16 -0
- node_modules/@nodelib/fs.stat/out/settings.js +16 -0
- node_modules/@nodelib/fs.stat/out/types/index.d.ts +4 -0
.gitignore
ADDED
|
@@ -0,0 +1,26 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
# Virtual environments
|
| 2 |
+
.venv/
|
| 3 |
+
venv/
|
| 4 |
+
|
| 5 |
+
# Python cache files
|
| 6 |
+
__pycache__/
|
| 7 |
+
*.pyc
|
| 8 |
+
*.pyo
|
| 9 |
+
*.pyd
|
| 10 |
+
|
| 11 |
+
# Large ML/Data files
|
| 12 |
+
*.csv
|
| 13 |
+
*.npy
|
| 14 |
+
*.pkl
|
| 15 |
+
*.h5
|
| 16 |
+
*.pt
|
| 17 |
+
*.pth
|
| 18 |
+
*.joblib
|
| 19 |
+
*.zip
|
| 20 |
+
*.tar
|
| 21 |
+
*.gz
|
| 22 |
+
*.npz
|
| 23 |
+
|
| 24 |
+
# OS/IDE files
|
| 25 |
+
.DS_Store
|
| 26 |
+
.vscode/
|
CleanedJobs.ipynb
ADDED
|
@@ -0,0 +1,1165 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
{
|
| 2 |
+
"cells": [
|
| 3 |
+
{
|
| 4 |
+
"cell_type": "code",
|
| 5 |
+
"execution_count": 1,
|
| 6 |
+
"metadata": {},
|
| 7 |
+
"outputs": [],
|
| 8 |
+
"source": [
|
| 9 |
+
"import pandas as pd"
|
| 10 |
+
]
|
| 11 |
+
},
|
| 12 |
+
{
|
| 13 |
+
"cell_type": "code",
|
| 14 |
+
"execution_count": null,
|
| 15 |
+
"metadata": {},
|
| 16 |
+
"outputs": [],
|
| 17 |
+
"source": []
|
| 18 |
+
},
|
| 19 |
+
{
|
| 20 |
+
"cell_type": "code",
|
| 21 |
+
"execution_count": 2,
|
| 22 |
+
"metadata": {},
|
| 23 |
+
"outputs": [
|
| 24 |
+
{
|
| 25 |
+
"name": "stderr",
|
| 26 |
+
"output_type": "stream",
|
| 27 |
+
"text": [
|
| 28 |
+
"<>:1: SyntaxWarning: invalid escape sequence '\\j'\n",
|
| 29 |
+
"<>:1: SyntaxWarning: invalid escape sequence '\\j'\n",
|
| 30 |
+
"C:\\Users\\HP\\AppData\\Local\\Temp\\ipykernel_17816\\3441334955.py:1: SyntaxWarning: invalid escape sequence '\\j'\n",
|
| 31 |
+
" Jobs = pd.read_csv(\"dataJobs\\job_descriptions.csv\")\n",
|
| 32 |
+
"C:\\Users\\HP\\AppData\\Local\\Temp\\ipykernel_17816\\3441334955.py:1: SyntaxWarning: invalid escape sequence '\\j'\n",
|
| 33 |
+
" Jobs = pd.read_csv(\"dataJobs\\job_descriptions.csv\")\n"
|
| 34 |
+
]
|
| 35 |
+
},
|
| 36 |
+
{
|
| 37 |
+
"ename": "FileNotFoundError",
|
| 38 |
+
"evalue": "[Errno 2] No such file or directory: 'dataJobs\\\\job_descriptions.csv'",
|
| 39 |
+
"output_type": "error",
|
| 40 |
+
"traceback": [
|
| 41 |
+
"\u001b[31m---------------------------------------------------------------------------\u001b[39m",
|
| 42 |
+
"\u001b[31mFileNotFoundError\u001b[39m Traceback (most recent call last)",
|
| 43 |
+
"\u001b[36mCell\u001b[39m\u001b[36m \u001b[39m\u001b[32mIn[2]\u001b[39m\u001b[32m, line 1\u001b[39m\n\u001b[32m----> \u001b[39m\u001b[32m1\u001b[39m Jobs = \u001b[43mpd\u001b[49m\u001b[43m.\u001b[49m\u001b[43mread_csv\u001b[49m\u001b[43m(\u001b[49m\u001b[33;43m\"\u001b[39;49m\u001b[33;43mdataJobs\u001b[39;49m\u001b[33;43m\\\u001b[39;49m\u001b[33;43mjob_descriptions.csv\u001b[39;49m\u001b[33;43m\"\u001b[39;49m\u001b[43m)\u001b[49m\n\u001b[32m 2\u001b[39m Jobs.shape\n",
|
| 44 |
+
"\u001b[36mFile \u001b[39m\u001b[32mc:\\Users\\HP\\OneDrive\\Desktop\\job-recommendation-system-ai-main\\venv\\Lib\\site-packages\\pandas\\io\\parsers\\readers.py:1026\u001b[39m, in \u001b[36mread_csv\u001b[39m\u001b[34m(filepath_or_buffer, sep, delimiter, header, names, index_col, usecols, dtype, engine, converters, true_values, false_values, skipinitialspace, skiprows, skipfooter, nrows, na_values, keep_default_na, na_filter, verbose, skip_blank_lines, parse_dates, infer_datetime_format, keep_date_col, date_parser, date_format, dayfirst, cache_dates, iterator, chunksize, compression, thousands, decimal, lineterminator, quotechar, quoting, doublequote, escapechar, comment, encoding, encoding_errors, dialect, on_bad_lines, delim_whitespace, low_memory, memory_map, float_precision, storage_options, dtype_backend)\u001b[39m\n\u001b[32m 1013\u001b[39m kwds_defaults = _refine_defaults_read(\n\u001b[32m 1014\u001b[39m dialect,\n\u001b[32m 1015\u001b[39m delimiter,\n\u001b[32m (...)\u001b[39m\u001b[32m 1022\u001b[39m dtype_backend=dtype_backend,\n\u001b[32m 1023\u001b[39m )\n\u001b[32m 1024\u001b[39m kwds.update(kwds_defaults)\n\u001b[32m-> \u001b[39m\u001b[32m1026\u001b[39m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43m_read\u001b[49m\u001b[43m(\u001b[49m\u001b[43mfilepath_or_buffer\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mkwds\u001b[49m\u001b[43m)\u001b[49m\n",
|
| 45 |
+
"\u001b[36mFile \u001b[39m\u001b[32mc:\\Users\\HP\\OneDrive\\Desktop\\job-recommendation-system-ai-main\\venv\\Lib\\site-packages\\pandas\\io\\parsers\\readers.py:620\u001b[39m, in \u001b[36m_read\u001b[39m\u001b[34m(filepath_or_buffer, kwds)\u001b[39m\n\u001b[32m 617\u001b[39m _validate_names(kwds.get(\u001b[33m\"\u001b[39m\u001b[33mnames\u001b[39m\u001b[33m\"\u001b[39m, \u001b[38;5;28;01mNone\u001b[39;00m))\n\u001b[32m 619\u001b[39m \u001b[38;5;66;03m# Create the parser.\u001b[39;00m\n\u001b[32m--> \u001b[39m\u001b[32m620\u001b[39m parser = \u001b[43mTextFileReader\u001b[49m\u001b[43m(\u001b[49m\u001b[43mfilepath_or_buffer\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43m*\u001b[49m\u001b[43m*\u001b[49m\u001b[43mkwds\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m 622\u001b[39m \u001b[38;5;28;01mif\u001b[39;00m chunksize \u001b[38;5;129;01mor\u001b[39;00m iterator:\n\u001b[32m 623\u001b[39m \u001b[38;5;28;01mreturn\u001b[39;00m parser\n",
|
| 46 |
+
"\u001b[36mFile \u001b[39m\u001b[32mc:\\Users\\HP\\OneDrive\\Desktop\\job-recommendation-system-ai-main\\venv\\Lib\\site-packages\\pandas\\io\\parsers\\readers.py:1620\u001b[39m, in \u001b[36mTextFileReader.__init__\u001b[39m\u001b[34m(self, f, engine, **kwds)\u001b[39m\n\u001b[32m 1617\u001b[39m \u001b[38;5;28mself\u001b[39m.options[\u001b[33m\"\u001b[39m\u001b[33mhas_index_names\u001b[39m\u001b[33m\"\u001b[39m] = kwds[\u001b[33m\"\u001b[39m\u001b[33mhas_index_names\u001b[39m\u001b[33m\"\u001b[39m]\n\u001b[32m 1619\u001b[39m \u001b[38;5;28mself\u001b[39m.handles: IOHandles | \u001b[38;5;28;01mNone\u001b[39;00m = \u001b[38;5;28;01mNone\u001b[39;00m\n\u001b[32m-> \u001b[39m\u001b[32m1620\u001b[39m \u001b[38;5;28mself\u001b[39m._engine = \u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43m_make_engine\u001b[49m\u001b[43m(\u001b[49m\u001b[43mf\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mengine\u001b[49m\u001b[43m)\u001b[49m\n",
|
| 47 |
+
"\u001b[36mFile \u001b[39m\u001b[32mc:\\Users\\HP\\OneDrive\\Desktop\\job-recommendation-system-ai-main\\venv\\Lib\\site-packages\\pandas\\io\\parsers\\readers.py:1880\u001b[39m, in \u001b[36mTextFileReader._make_engine\u001b[39m\u001b[34m(self, f, engine)\u001b[39m\n\u001b[32m 1878\u001b[39m \u001b[38;5;28;01mif\u001b[39;00m \u001b[33m\"\u001b[39m\u001b[33mb\u001b[39m\u001b[33m\"\u001b[39m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;129;01min\u001b[39;00m mode:\n\u001b[32m 1879\u001b[39m mode += \u001b[33m\"\u001b[39m\u001b[33mb\u001b[39m\u001b[33m\"\u001b[39m\n\u001b[32m-> \u001b[39m\u001b[32m1880\u001b[39m \u001b[38;5;28mself\u001b[39m.handles = \u001b[43mget_handle\u001b[49m\u001b[43m(\u001b[49m\n\u001b[32m 1881\u001b[39m \u001b[43m \u001b[49m\u001b[43mf\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m 1882\u001b[39m \u001b[43m \u001b[49m\u001b[43mmode\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m 1883\u001b[39m \u001b[43m \u001b[49m\u001b[43mencoding\u001b[49m\u001b[43m=\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43moptions\u001b[49m\u001b[43m.\u001b[49m\u001b[43mget\u001b[49m\u001b[43m(\u001b[49m\u001b[33;43m\"\u001b[39;49m\u001b[33;43mencoding\u001b[39;49m\u001b[33;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43;01mNone\u001b[39;49;00m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m 1884\u001b[39m \u001b[43m \u001b[49m\u001b[43mcompression\u001b[49m\u001b[43m=\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43moptions\u001b[49m\u001b[43m.\u001b[49m\u001b[43mget\u001b[49m\u001b[43m(\u001b[49m\u001b[33;43m\"\u001b[39;49m\u001b[33;43mcompression\u001b[39;49m\u001b[33;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43;01mNone\u001b[39;49;00m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m 1885\u001b[39m \u001b[43m \u001b[49m\u001b[43mmemory_map\u001b[49m\u001b[43m=\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43moptions\u001b[49m\u001b[43m.\u001b[49m\u001b[43mget\u001b[49m\u001b[43m(\u001b[49m\u001b[33;43m\"\u001b[39;49m\u001b[33;43mmemory_map\u001b[39;49m\u001b[33;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43;01mFalse\u001b[39;49;00m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m 1886\u001b[39m \u001b[43m \u001b[49m\u001b[43mis_text\u001b[49m\u001b[43m=\u001b[49m\u001b[43mis_text\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m 1887\u001b[39m \u001b[43m \u001b[49m\u001b[43merrors\u001b[49m\u001b[43m=\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43moptions\u001b[49m\u001b[43m.\u001b[49m\u001b[43mget\u001b[49m\u001b[43m(\u001b[49m\u001b[33;43m\"\u001b[39;49m\u001b[33;43mencoding_errors\u001b[39;49m\u001b[33;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[33;43m\"\u001b[39;49m\u001b[33;43mstrict\u001b[39;49m\u001b[33;43m\"\u001b[39;49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m 1888\u001b[39m \u001b[43m \u001b[49m\u001b[43mstorage_options\u001b[49m\u001b[43m=\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43moptions\u001b[49m\u001b[43m.\u001b[49m\u001b[43mget\u001b[49m\u001b[43m(\u001b[49m\u001b[33;43m\"\u001b[39;49m\u001b[33;43mstorage_options\u001b[39;49m\u001b[33;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43;01mNone\u001b[39;49;00m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m 1889\u001b[39m \u001b[43m\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m 1890\u001b[39m \u001b[38;5;28;01massert\u001b[39;00m \u001b[38;5;28mself\u001b[39m.handles \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m\n\u001b[32m 1891\u001b[39m f = \u001b[38;5;28mself\u001b[39m.handles.handle\n",
|
| 48 |
+
"\u001b[36mFile \u001b[39m\u001b[32mc:\\Users\\HP\\OneDrive\\Desktop\\job-recommendation-system-ai-main\\venv\\Lib\\site-packages\\pandas\\io\\common.py:873\u001b[39m, in \u001b[36mget_handle\u001b[39m\u001b[34m(path_or_buf, mode, encoding, compression, memory_map, is_text, errors, storage_options)\u001b[39m\n\u001b[32m 868\u001b[39m \u001b[38;5;28;01melif\u001b[39;00m \u001b[38;5;28misinstance\u001b[39m(handle, \u001b[38;5;28mstr\u001b[39m):\n\u001b[32m 869\u001b[39m \u001b[38;5;66;03m# Check whether the filename is to be opened in binary mode.\u001b[39;00m\n\u001b[32m 870\u001b[39m \u001b[38;5;66;03m# Binary mode does not support 'encoding' and 'newline'.\u001b[39;00m\n\u001b[32m 871\u001b[39m \u001b[38;5;28;01mif\u001b[39;00m ioargs.encoding \u001b[38;5;129;01mand\u001b[39;00m \u001b[33m\"\u001b[39m\u001b[33mb\u001b[39m\u001b[33m\"\u001b[39m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;129;01min\u001b[39;00m ioargs.mode:\n\u001b[32m 872\u001b[39m \u001b[38;5;66;03m# Encoding\u001b[39;00m\n\u001b[32m--> \u001b[39m\u001b[32m873\u001b[39m handle = \u001b[38;5;28;43mopen\u001b[39;49m\u001b[43m(\u001b[49m\n\u001b[32m 874\u001b[39m \u001b[43m \u001b[49m\u001b[43mhandle\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m 875\u001b[39m \u001b[43m \u001b[49m\u001b[43mioargs\u001b[49m\u001b[43m.\u001b[49m\u001b[43mmode\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m 876\u001b[39m \u001b[43m \u001b[49m\u001b[43mencoding\u001b[49m\u001b[43m=\u001b[49m\u001b[43mioargs\u001b[49m\u001b[43m.\u001b[49m\u001b[43mencoding\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m 877\u001b[39m \u001b[43m \u001b[49m\u001b[43merrors\u001b[49m\u001b[43m=\u001b[49m\u001b[43merrors\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m 878\u001b[39m \u001b[43m \u001b[49m\u001b[43mnewline\u001b[49m\u001b[43m=\u001b[49m\u001b[33;43m\"\u001b[39;49m\u001b[33;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\n\u001b[32m 879\u001b[39m \u001b[43m \u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m 880\u001b[39m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[32m 881\u001b[39m \u001b[38;5;66;03m# Binary mode\u001b[39;00m\n\u001b[32m 882\u001b[39m handle = \u001b[38;5;28mopen\u001b[39m(handle, ioargs.mode)\n",
|
| 49 |
+
"\u001b[31mFileNotFoundError\u001b[39m: [Errno 2] No such file or directory: 'dataJobs\\\\job_descriptions.csv'"
|
| 50 |
+
]
|
| 51 |
+
}
|
| 52 |
+
],
|
| 53 |
+
"source": [
|
| 54 |
+
"Jobs = pd.read_csv(\"dataJobs\\job_descriptions.csv\")\n",
|
| 55 |
+
"Jobs.shape"
|
| 56 |
+
]
|
| 57 |
+
},
|
| 58 |
+
{
|
| 59 |
+
"cell_type": "code",
|
| 60 |
+
"execution_count": 3,
|
| 61 |
+
"metadata": {},
|
| 62 |
+
"outputs": [
|
| 63 |
+
{
|
| 64 |
+
"ename": "NameError",
|
| 65 |
+
"evalue": "name 'Jobs' is not defined",
|
| 66 |
+
"output_type": "error",
|
| 67 |
+
"traceback": [
|
| 68 |
+
"\u001b[31m---------------------------------------------------------------------------\u001b[39m",
|
| 69 |
+
"\u001b[31mNameError\u001b[39m Traceback (most recent call last)",
|
| 70 |
+
"\u001b[36mCell\u001b[39m\u001b[36m \u001b[39m\u001b[32mIn[3]\u001b[39m\u001b[32m, line 1\u001b[39m\n\u001b[32m----> \u001b[39m\u001b[32m1\u001b[39m Jobs_shuffled = \u001b[43mJobs\u001b[49m.sample(frac=\u001b[32m1\u001b[39m, random_state=\u001b[32m42\u001b[39m).reset_index(drop=\u001b[38;5;28;01mTrue\u001b[39;00m)\n",
|
| 71 |
+
"\u001b[31mNameError\u001b[39m: name 'Jobs' is not defined"
|
| 72 |
+
]
|
| 73 |
+
}
|
| 74 |
+
],
|
| 75 |
+
"source": [
|
| 76 |
+
"Jobs_shuffled = Jobs.sample(frac=1, random_state=42).reset_index(drop=True)"
|
| 77 |
+
]
|
| 78 |
+
},
|
| 79 |
+
{
|
| 80 |
+
"cell_type": "code",
|
| 81 |
+
"execution_count": null,
|
| 82 |
+
"metadata": {},
|
| 83 |
+
"outputs": [],
|
| 84 |
+
"source": [
|
| 85 |
+
"FinalJobs = Jobs_shuffled.iloc[:10000]"
|
| 86 |
+
]
|
| 87 |
+
},
|
| 88 |
+
{
|
| 89 |
+
"cell_type": "code",
|
| 90 |
+
"execution_count": null,
|
| 91 |
+
"metadata": {},
|
| 92 |
+
"outputs": [
|
| 93 |
+
{
|
| 94 |
+
"data": {
|
| 95 |
+
"text/plain": [
|
| 96 |
+
"(Index(['Job Id', 'Experience', 'Qualifications', 'Salary Range', 'location',\n",
|
| 97 |
+
" 'Country', 'latitude', 'longitude', 'Work Type', 'Company Size',\n",
|
| 98 |
+
" 'Job Posting Date', 'Preference', 'Contact Person', 'Contact',\n",
|
| 99 |
+
" 'Job Title', 'Role', 'Job Portal', 'Job Description', 'Benefits',\n",
|
| 100 |
+
" 'skills', 'Responsibilities', 'Company', 'Company Profile'],\n",
|
| 101 |
+
" dtype='object'),\n",
|
| 102 |
+
" (10000, 23))"
|
| 103 |
+
]
|
| 104 |
+
},
|
| 105 |
+
"execution_count": 6,
|
| 106 |
+
"metadata": {},
|
| 107 |
+
"output_type": "execute_result"
|
| 108 |
+
}
|
| 109 |
+
],
|
| 110 |
+
"source": [
|
| 111 |
+
"#FinalJobs.to_csv(\"Jobs.csv\" , index= False)\n",
|
| 112 |
+
"FinalJobs.columns, FinalJobs.shape"
|
| 113 |
+
]
|
| 114 |
+
},
|
| 115 |
+
{
|
| 116 |
+
"cell_type": "code",
|
| 117 |
+
"execution_count": 7,
|
| 118 |
+
"metadata": {},
|
| 119 |
+
"outputs": [
|
| 120 |
+
{
|
| 121 |
+
"data": {
|
| 122 |
+
"text/html": [
|
| 123 |
+
"<div>\n",
|
| 124 |
+
"<style scoped>\n",
|
| 125 |
+
" .dataframe tbody tr th:only-of-type {\n",
|
| 126 |
+
" vertical-align: middle;\n",
|
| 127 |
+
" }\n",
|
| 128 |
+
"\n",
|
| 129 |
+
" .dataframe tbody tr th {\n",
|
| 130 |
+
" vertical-align: top;\n",
|
| 131 |
+
" }\n",
|
| 132 |
+
"\n",
|
| 133 |
+
" .dataframe thead th {\n",
|
| 134 |
+
" text-align: right;\n",
|
| 135 |
+
" }\n",
|
| 136 |
+
"</style>\n",
|
| 137 |
+
"<table border=\"1\" class=\"dataframe\">\n",
|
| 138 |
+
" <thead>\n",
|
| 139 |
+
" <tr style=\"text-align: right;\">\n",
|
| 140 |
+
" <th></th>\n",
|
| 141 |
+
" <th>Job Id</th>\n",
|
| 142 |
+
" <th>Experience</th>\n",
|
| 143 |
+
" <th>Qualifications</th>\n",
|
| 144 |
+
" <th>Salary Range</th>\n",
|
| 145 |
+
" <th>location</th>\n",
|
| 146 |
+
" <th>Country</th>\n",
|
| 147 |
+
" <th>latitude</th>\n",
|
| 148 |
+
" <th>longitude</th>\n",
|
| 149 |
+
" <th>Work Type</th>\n",
|
| 150 |
+
" <th>Company Size</th>\n",
|
| 151 |
+
" <th>...</th>\n",
|
| 152 |
+
" <th>Contact</th>\n",
|
| 153 |
+
" <th>Job Title</th>\n",
|
| 154 |
+
" <th>Role</th>\n",
|
| 155 |
+
" <th>Job Portal</th>\n",
|
| 156 |
+
" <th>Job Description</th>\n",
|
| 157 |
+
" <th>Benefits</th>\n",
|
| 158 |
+
" <th>skills</th>\n",
|
| 159 |
+
" <th>Responsibilities</th>\n",
|
| 160 |
+
" <th>Company</th>\n",
|
| 161 |
+
" <th>Company Profile</th>\n",
|
| 162 |
+
" </tr>\n",
|
| 163 |
+
" </thead>\n",
|
| 164 |
+
" <tbody>\n",
|
| 165 |
+
" <tr>\n",
|
| 166 |
+
" <th>8573</th>\n",
|
| 167 |
+
" <td>1901955228738870</td>\n",
|
| 168 |
+
" <td>3 to 10 Years</td>\n",
|
| 169 |
+
" <td>MBA</td>\n",
|
| 170 |
+
" <td>$62K-$100K</td>\n",
|
| 171 |
+
" <td>Kampala</td>\n",
|
| 172 |
+
" <td>Uganda</td>\n",
|
| 173 |
+
" <td>1.3733</td>\n",
|
| 174 |
+
" <td>32.2903</td>\n",
|
| 175 |
+
" <td>Full-Time</td>\n",
|
| 176 |
+
" <td>115838</td>\n",
|
| 177 |
+
" <td>...</td>\n",
|
| 178 |
+
" <td>+1-597-207-4474</td>\n",
|
| 179 |
+
" <td>Legal Advisor</td>\n",
|
| 180 |
+
" <td>In-House Counsel</td>\n",
|
| 181 |
+
" <td>Dice</td>\n",
|
| 182 |
+
" <td>In the role of In-House Counsel, you will prov...</td>\n",
|
| 183 |
+
" <td>{'Casual Dress Code, Social and Recreational A...</td>\n",
|
| 184 |
+
" <td>In-house counsel Legal advisory Employment law...</td>\n",
|
| 185 |
+
" <td>Serve as in-house legal counsel for organizati...</td>\n",
|
| 186 |
+
" <td>Oracle</td>\n",
|
| 187 |
+
" <td>{\"Sector\":\"Technology\",\"Industry\":\"Computer So...</td>\n",
|
| 188 |
+
" </tr>\n",
|
| 189 |
+
" </tbody>\n",
|
| 190 |
+
"</table>\n",
|
| 191 |
+
"<p>1 rows × 23 columns</p>\n",
|
| 192 |
+
"</div>"
|
| 193 |
+
],
|
| 194 |
+
"text/plain": [
|
| 195 |
+
" Job Id Experience Qualifications Salary Range location \\\n",
|
| 196 |
+
"8573 1901955228738870 3 to 10 Years MBA $62K-$100K Kampala \n",
|
| 197 |
+
"\n",
|
| 198 |
+
" Country latitude longitude Work Type Company Size ... \\\n",
|
| 199 |
+
"8573 Uganda 1.3733 32.2903 Full-Time 115838 ... \n",
|
| 200 |
+
"\n",
|
| 201 |
+
" Contact Job Title Role Job Portal \\\n",
|
| 202 |
+
"8573 +1-597-207-4474 Legal Advisor In-House Counsel Dice \n",
|
| 203 |
+
"\n",
|
| 204 |
+
" Job Description \\\n",
|
| 205 |
+
"8573 In the role of In-House Counsel, you will prov... \n",
|
| 206 |
+
"\n",
|
| 207 |
+
" Benefits \\\n",
|
| 208 |
+
"8573 {'Casual Dress Code, Social and Recreational A... \n",
|
| 209 |
+
"\n",
|
| 210 |
+
" skills \\\n",
|
| 211 |
+
"8573 In-house counsel Legal advisory Employment law... \n",
|
| 212 |
+
"\n",
|
| 213 |
+
" Responsibilities Company \\\n",
|
| 214 |
+
"8573 Serve as in-house legal counsel for organizati... Oracle \n",
|
| 215 |
+
"\n",
|
| 216 |
+
" Company Profile \n",
|
| 217 |
+
"8573 {\"Sector\":\"Technology\",\"Industry\":\"Computer So... \n",
|
| 218 |
+
"\n",
|
| 219 |
+
"[1 rows x 23 columns]"
|
| 220 |
+
]
|
| 221 |
+
},
|
| 222 |
+
"execution_count": 7,
|
| 223 |
+
"metadata": {},
|
| 224 |
+
"output_type": "execute_result"
|
| 225 |
+
}
|
| 226 |
+
],
|
| 227 |
+
"source": [
|
| 228 |
+
"FinalJobs.sample(1)"
|
| 229 |
+
]
|
| 230 |
+
},
|
| 231 |
+
{
|
| 232 |
+
"cell_type": "code",
|
| 233 |
+
"execution_count": 8,
|
| 234 |
+
"metadata": {},
|
| 235 |
+
"outputs": [
|
| 236 |
+
{
|
| 237 |
+
"name": "stderr",
|
| 238 |
+
"output_type": "stream",
|
| 239 |
+
"text": [
|
| 240 |
+
"C:\\Users\\LAPSHOP\\AppData\\Local\\Temp\\ipykernel_24448\\857821168.py:2: SettingWithCopyWarning: \n",
|
| 241 |
+
"A value is trying to be set on a copy of a slice from a DataFrame.\n",
|
| 242 |
+
"Try using .loc[row_indexer,col_indexer] = value instead\n",
|
| 243 |
+
"\n",
|
| 244 |
+
"See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
|
| 245 |
+
" FinalJobs[\"workplace\"]= FinalJobs[\"location\"]+\" \"+FinalJobs[\"Country\"]\n",
|
| 246 |
+
"C:\\Users\\LAPSHOP\\AppData\\Local\\Temp\\ipykernel_24448\\857821168.py:4: SettingWithCopyWarning: \n",
|
| 247 |
+
"A value is trying to be set on a copy of a slice from a DataFrame.\n",
|
| 248 |
+
"Try using .loc[row_indexer,col_indexer] = value instead\n",
|
| 249 |
+
"\n",
|
| 250 |
+
"See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
|
| 251 |
+
" FinalJobs[\"working_mode\"] = FinalJobs[\"Work Type\"]\n",
|
| 252 |
+
"C:\\Users\\LAPSHOP\\AppData\\Local\\Temp\\ipykernel_24448\\857821168.py:15: SettingWithCopyWarning: \n",
|
| 253 |
+
"A value is trying to be set on a copy of a slice from a DataFrame.\n",
|
| 254 |
+
"Try using .loc[row_indexer,col_indexer] = value instead\n",
|
| 255 |
+
"\n",
|
| 256 |
+
"See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
|
| 257 |
+
" FinalJobs[\"salary\"] = FinalJobs[\"Salary Range\"].apply(calculate_avg_salary)\n",
|
| 258 |
+
"C:\\Users\\LAPSHOP\\AppData\\Local\\Temp\\ipykernel_24448\\857821168.py:18: SettingWithCopyWarning: \n",
|
| 259 |
+
"A value is trying to be set on a copy of a slice from a DataFrame.\n",
|
| 260 |
+
"Try using .loc[row_indexer,col_indexer] = value instead\n",
|
| 261 |
+
"\n",
|
| 262 |
+
"See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
|
| 263 |
+
" FinalJobs[\"position\"] = FinalJobs[\"Job Title\"]\n",
|
| 264 |
+
"C:\\Users\\LAPSHOP\\AppData\\Local\\Temp\\ipykernel_24448\\857821168.py:21: SettingWithCopyWarning: \n",
|
| 265 |
+
"A value is trying to be set on a copy of a slice from a DataFrame.\n",
|
| 266 |
+
"Try using .loc[row_indexer,col_indexer] = value instead\n",
|
| 267 |
+
"\n",
|
| 268 |
+
"See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
|
| 269 |
+
" FinalJobs[\"job_role_and_duties\"] = FinalJobs[\"Responsibilities\"] +\" \" + FinalJobs[\"Role\"] + FinalJobs[\"Job Description\"]\n",
|
| 270 |
+
"C:\\Users\\LAPSHOP\\AppData\\Local\\Temp\\ipykernel_24448\\857821168.py:24: SettingWithCopyWarning: \n",
|
| 271 |
+
"A value is trying to be set on a copy of a slice from a DataFrame.\n",
|
| 272 |
+
"Try using .loc[row_indexer,col_indexer] = value instead\n",
|
| 273 |
+
"\n",
|
| 274 |
+
"See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
|
| 275 |
+
" FinalJobs[\"requisite_skill\"] = FinalJobs[\"skills\"] + \" \" + FinalJobs[\"Experience\"] +\" \"+ FinalJobs[\"Qualifications\"]\n",
|
| 276 |
+
"C:\\Users\\LAPSHOP\\AppData\\Local\\Temp\\ipykernel_24448\\857821168.py:27: SettingWithCopyWarning: \n",
|
| 277 |
+
"A value is trying to be set on a copy of a slice from a DataFrame.\n",
|
| 278 |
+
"Try using .loc[row_indexer,col_indexer] = value instead\n",
|
| 279 |
+
"\n",
|
| 280 |
+
"See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
|
| 281 |
+
" FinalJobs[\"offer_details\"] = FinalJobs[\"Benefits\"]\n"
|
| 282 |
+
]
|
| 283 |
+
}
|
| 284 |
+
],
|
| 285 |
+
"source": [
|
| 286 |
+
"# 1. Create \"workplace\" column from \"location\" and \"country\"\n",
|
| 287 |
+
"FinalJobs[\"workplace\"]= FinalJobs[\"location\"]+\" \"+FinalJobs[\"Country\"]\n",
|
| 288 |
+
"# 3. Create \"working_mode\" column from \"Work Type\"\n",
|
| 289 |
+
"FinalJobs[\"working_mode\"] = FinalJobs[\"Work Type\"]\n",
|
| 290 |
+
"\n",
|
| 291 |
+
"# 4. Create \"salary\" column by calculating the average of Salary Range\n",
|
| 292 |
+
"def calculate_avg_salary(salary_range):\n",
|
| 293 |
+
" if isinstance(salary_range, str) and \"-\" in salary_range:\n",
|
| 294 |
+
" salary_range = salary_range.replace(\"$\", \"\").replace(\"K\", \"\").split(\"-\")\n",
|
| 295 |
+
" min_salary = float(salary_range[0]) * 1000\n",
|
| 296 |
+
" max_salary = float(salary_range[1]) * 1000\n",
|
| 297 |
+
" return (min_salary + max_salary) / 2\n",
|
| 298 |
+
" return None\n",
|
| 299 |
+
"\n",
|
| 300 |
+
"FinalJobs[\"salary\"] = FinalJobs[\"Salary Range\"].apply(calculate_avg_salary)\n",
|
| 301 |
+
"\n",
|
| 302 |
+
"# 5. Create \"position\" column from \"Job Title\"\n",
|
| 303 |
+
"FinalJobs[\"position\"] = FinalJobs[\"Job Title\"]\n",
|
| 304 |
+
"\n",
|
| 305 |
+
"# 6. Create \"job_role_and_duties\" from \"Responsibilities\", \"Role\", and \"Job Description\"\n",
|
| 306 |
+
"FinalJobs[\"job_role_and_duties\"] = FinalJobs[\"Responsibilities\"] +\" \" + FinalJobs[\"Role\"] + FinalJobs[\"Job Description\"]\n",
|
| 307 |
+
"\n",
|
| 308 |
+
"# 7. Create \"requisite_skill\" from \"skills\", \"Experience\", and \"Qualifications\"\n",
|
| 309 |
+
"FinalJobs[\"requisite_skill\"] = FinalJobs[\"skills\"] + \" \" + FinalJobs[\"Experience\"] +\" \"+ FinalJobs[\"Qualifications\"]\n",
|
| 310 |
+
"\n",
|
| 311 |
+
"# 8. Create \"offer_details\" from \"Benefits\"\n",
|
| 312 |
+
"FinalJobs[\"offer_details\"] = FinalJobs[\"Benefits\"]\n",
|
| 313 |
+
"\n",
|
| 314 |
+
"# Drop unnecessary columns (optional)\n",
|
| 315 |
+
"FinalJobs = FinalJobs.drop(columns=[\"location\", \"Country\", \"latitude\", \"longitude\", \"Work Type\", \"Salary Range\",\n",
|
| 316 |
+
" \"Job Title\", \"Responsibilities\", \"Role\", \"Job Description\",\n",
|
| 317 |
+
" \"skills\", \"Experience\", \"Qualifications\", \"Benefits\"])\n"
|
| 318 |
+
]
|
| 319 |
+
},
|
| 320 |
+
{
|
| 321 |
+
"cell_type": "code",
|
| 322 |
+
"execution_count": 9,
|
| 323 |
+
"metadata": {},
|
| 324 |
+
"outputs": [
|
| 325 |
+
{
|
| 326 |
+
"data": {
|
| 327 |
+
"text/plain": [
|
| 328 |
+
"Index(['Job Id', 'Company Size', 'Job Posting Date', 'Preference',\n",
|
| 329 |
+
" 'Contact Person', 'Contact', 'Job Portal', 'Company', 'Company Profile',\n",
|
| 330 |
+
" 'workplace', 'working_mode', 'salary', 'position',\n",
|
| 331 |
+
" 'job_role_and_duties', 'requisite_skill', 'offer_details'],\n",
|
| 332 |
+
" dtype='object')"
|
| 333 |
+
]
|
| 334 |
+
},
|
| 335 |
+
"execution_count": 9,
|
| 336 |
+
"metadata": {},
|
| 337 |
+
"output_type": "execute_result"
|
| 338 |
+
}
|
| 339 |
+
],
|
| 340 |
+
"source": [
|
| 341 |
+
"FinalJobs.columns"
|
| 342 |
+
]
|
| 343 |
+
},
|
| 344 |
+
{
|
| 345 |
+
"cell_type": "code",
|
| 346 |
+
"execution_count": 10,
|
| 347 |
+
"metadata": {},
|
| 348 |
+
"outputs": [],
|
| 349 |
+
"source": [
|
| 350 |
+
"FinalJobs = FinalJobs.drop(columns=['Company Size', 'Job Posting Date', 'Preference','Contact Person', 'Contact', 'Job Portal', 'Company', 'Company Profile'])"
|
| 351 |
+
]
|
| 352 |
+
},
|
| 353 |
+
{
|
| 354 |
+
"cell_type": "code",
|
| 355 |
+
"execution_count": 11,
|
| 356 |
+
"metadata": {},
|
| 357 |
+
"outputs": [
|
| 358 |
+
{
|
| 359 |
+
"data": {
|
| 360 |
+
"text/plain": [
|
| 361 |
+
"Index(['Job Id', 'workplace', 'working_mode', 'salary', 'position',\n",
|
| 362 |
+
" 'job_role_and_duties', 'requisite_skill', 'offer_details'],\n",
|
| 363 |
+
" dtype='object')"
|
| 364 |
+
]
|
| 365 |
+
},
|
| 366 |
+
"execution_count": 11,
|
| 367 |
+
"metadata": {},
|
| 368 |
+
"output_type": "execute_result"
|
| 369 |
+
}
|
| 370 |
+
],
|
| 371 |
+
"source": [
|
| 372 |
+
"FinalJobs.columns"
|
| 373 |
+
]
|
| 374 |
+
},
|
| 375 |
+
{
|
| 376 |
+
"cell_type": "code",
|
| 377 |
+
"execution_count": 12,
|
| 378 |
+
"metadata": {},
|
| 379 |
+
"outputs": [
|
| 380 |
+
{
|
| 381 |
+
"data": {
|
| 382 |
+
"text/html": [
|
| 383 |
+
"<div>\n",
|
| 384 |
+
"<style scoped>\n",
|
| 385 |
+
" .dataframe tbody tr th:only-of-type {\n",
|
| 386 |
+
" vertical-align: middle;\n",
|
| 387 |
+
" }\n",
|
| 388 |
+
"\n",
|
| 389 |
+
" .dataframe tbody tr th {\n",
|
| 390 |
+
" vertical-align: top;\n",
|
| 391 |
+
" }\n",
|
| 392 |
+
"\n",
|
| 393 |
+
" .dataframe thead th {\n",
|
| 394 |
+
" text-align: right;\n",
|
| 395 |
+
" }\n",
|
| 396 |
+
"</style>\n",
|
| 397 |
+
"<table border=\"1\" class=\"dataframe\">\n",
|
| 398 |
+
" <thead>\n",
|
| 399 |
+
" <tr style=\"text-align: right;\">\n",
|
| 400 |
+
" <th></th>\n",
|
| 401 |
+
" <th>Job Id</th>\n",
|
| 402 |
+
" <th>workplace</th>\n",
|
| 403 |
+
" <th>working_mode</th>\n",
|
| 404 |
+
" <th>salary</th>\n",
|
| 405 |
+
" <th>position</th>\n",
|
| 406 |
+
" <th>job_role_and_duties</th>\n",
|
| 407 |
+
" <th>requisite_skill</th>\n",
|
| 408 |
+
" <th>offer_details</th>\n",
|
| 409 |
+
" </tr>\n",
|
| 410 |
+
" </thead>\n",
|
| 411 |
+
" <tbody>\n",
|
| 412 |
+
" <tr>\n",
|
| 413 |
+
" <th>9713</th>\n",
|
| 414 |
+
" <td>2049802603799610</td>\n",
|
| 415 |
+
" <td>Jerusalem Israel</td>\n",
|
| 416 |
+
" <td>Part-Time</td>\n",
|
| 417 |
+
" <td>75500.0</td>\n",
|
| 418 |
+
" <td>Process Engineer</td>\n",
|
| 419 |
+
" <td>Specialize in chemical processes, including de...</td>\n",
|
| 420 |
+
" <td>Chemical engineering Process design Chemical r...</td>\n",
|
| 421 |
+
" <td>{'Casual Dress Code, Social and Recreational A...</td>\n",
|
| 422 |
+
" </tr>\n",
|
| 423 |
+
" </tbody>\n",
|
| 424 |
+
"</table>\n",
|
| 425 |
+
"</div>"
|
| 426 |
+
],
|
| 427 |
+
"text/plain": [
|
| 428 |
+
" Job Id workplace working_mode salary \\\n",
|
| 429 |
+
"9713 2049802603799610 Jerusalem Israel Part-Time 75500.0 \n",
|
| 430 |
+
"\n",
|
| 431 |
+
" position job_role_and_duties \\\n",
|
| 432 |
+
"9713 Process Engineer Specialize in chemical processes, including de... \n",
|
| 433 |
+
"\n",
|
| 434 |
+
" requisite_skill \\\n",
|
| 435 |
+
"9713 Chemical engineering Process design Chemical r... \n",
|
| 436 |
+
"\n",
|
| 437 |
+
" offer_details \n",
|
| 438 |
+
"9713 {'Casual Dress Code, Social and Recreational A... "
|
| 439 |
+
]
|
| 440 |
+
},
|
| 441 |
+
"execution_count": 12,
|
| 442 |
+
"metadata": {},
|
| 443 |
+
"output_type": "execute_result"
|
| 444 |
+
}
|
| 445 |
+
],
|
| 446 |
+
"source": [
|
| 447 |
+
"FinalJobs.sample(1)"
|
| 448 |
+
]
|
| 449 |
+
},
|
| 450 |
+
{
|
| 451 |
+
"cell_type": "code",
|
| 452 |
+
"execution_count": 13,
|
| 453 |
+
"metadata": {},
|
| 454 |
+
"outputs": [
|
| 455 |
+
{
|
| 456 |
+
"name": "stdout",
|
| 457 |
+
"output_type": "stream",
|
| 458 |
+
"text": [
|
| 459 |
+
"Job Id is 1017340707950150\n",
|
| 460 |
+
"workplace is Panama City Panama\n",
|
| 461 |
+
"working_mode is Contract\n",
|
| 462 |
+
"salary is 69500.0\n",
|
| 463 |
+
"position is Procurement Manager\n",
|
| 464 |
+
"job_role_and_duties is Promote supplier diversity initiatives and inclusion. Identify and onboard diverse suppliers. Monitor compliance with diversity goals and regulations. Supplier Diversity ManagerPromote diversity and inclusion in the supply chain, manage supplier diversity programs, and assess supplier performance.\n",
|
| 465 |
+
"requisite_skill is Supplier diversity programs Diversity and inclusion initiatives Supplier assessment and certification Data collection and reporting Vendor outreach and engagement Strategic planning Communication skills Relationship building Attention to diversity and inclusion principles 5 to 10 Years BBA\n",
|
| 466 |
+
"offer_details is {'Transportation Benefits, Professional Development, Bonuses and Incentive Programs, Profit-Sharing, Employee Discounts'}\n"
|
| 467 |
+
]
|
| 468 |
+
}
|
| 469 |
+
],
|
| 470 |
+
"source": [
|
| 471 |
+
"for i in FinalJobs.columns:\n",
|
| 472 |
+
" print( i , \"is \", FinalJobs[i][0])"
|
| 473 |
+
]
|
| 474 |
+
},
|
| 475 |
+
{
|
| 476 |
+
"cell_type": "code",
|
| 477 |
+
"execution_count": 13,
|
| 478 |
+
"metadata": {},
|
| 479 |
+
"outputs": [
|
| 480 |
+
{
|
| 481 |
+
"name": "stderr",
|
| 482 |
+
"output_type": "stream",
|
| 483 |
+
"text": [
|
| 484 |
+
"[nltk_data] Downloading package punkt to\n",
|
| 485 |
+
"[nltk_data] C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 486 |
+
"[nltk_data] Package punkt is already up-to-date!\n",
|
| 487 |
+
"[nltk_data] Downloading package stopwords to\n",
|
| 488 |
+
"[nltk_data] C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 489 |
+
"[nltk_data] Unzipping corpora\\stopwords.zip.\n"
|
| 490 |
+
]
|
| 491 |
+
},
|
| 492 |
+
{
|
| 493 |
+
"data": {
|
| 494 |
+
"text/plain": [
|
| 495 |
+
"True"
|
| 496 |
+
]
|
| 497 |
+
},
|
| 498 |
+
"execution_count": 13,
|
| 499 |
+
"metadata": {},
|
| 500 |
+
"output_type": "execute_result"
|
| 501 |
+
}
|
| 502 |
+
],
|
| 503 |
+
"source": [
|
| 504 |
+
"import pandas as pd\n",
|
| 505 |
+
"import re\n",
|
| 506 |
+
"import nltk\n",
|
| 507 |
+
"from nltk.corpus import stopwords\n",
|
| 508 |
+
"from nltk.tokenize import word_tokenize\n",
|
| 509 |
+
"\n",
|
| 510 |
+
"# Download NLTK resources (if not already downloaded)\n",
|
| 511 |
+
"nltk.download('punkt')\n",
|
| 512 |
+
"nltk.download('stopwords')"
|
| 513 |
+
]
|
| 514 |
+
},
|
| 515 |
+
{
|
| 516 |
+
"cell_type": "code",
|
| 517 |
+
"execution_count": 14,
|
| 518 |
+
"metadata": {},
|
| 519 |
+
"outputs": [
|
| 520 |
+
{
|
| 521 |
+
"name": "stderr",
|
| 522 |
+
"output_type": "stream",
|
| 523 |
+
"text": [
|
| 524 |
+
"[nltk_data] Downloading collection 'all'\n",
|
| 525 |
+
"[nltk_data] | \n",
|
| 526 |
+
"[nltk_data] | Downloading package abc to\n",
|
| 527 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 528 |
+
"[nltk_data] | Package abc is already up-to-date!\n",
|
| 529 |
+
"[nltk_data] | Downloading package alpino to\n",
|
| 530 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 531 |
+
"[nltk_data] | Package alpino is already up-to-date!\n",
|
| 532 |
+
"[nltk_data] | Downloading package averaged_perceptron_tagger to\n",
|
| 533 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 534 |
+
"[nltk_data] | Package averaged_perceptron_tagger is already up-\n",
|
| 535 |
+
"[nltk_data] | to-date!\n",
|
| 536 |
+
"[nltk_data] | Downloading package averaged_perceptron_tagger_eng to\n",
|
| 537 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 538 |
+
"[nltk_data] | Package averaged_perceptron_tagger_eng is already\n",
|
| 539 |
+
"[nltk_data] | up-to-date!\n",
|
| 540 |
+
"[nltk_data] | Downloading package averaged_perceptron_tagger_ru to\n",
|
| 541 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 542 |
+
"[nltk_data] | Package averaged_perceptron_tagger_ru is already\n",
|
| 543 |
+
"[nltk_data] | up-to-date!\n",
|
| 544 |
+
"[nltk_data] | Downloading package averaged_perceptron_tagger_rus to\n",
|
| 545 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 546 |
+
"[nltk_data] | Package averaged_perceptron_tagger_rus is already\n",
|
| 547 |
+
"[nltk_data] | up-to-date!\n",
|
| 548 |
+
"[nltk_data] | Downloading package basque_grammars to\n",
|
| 549 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 550 |
+
"[nltk_data] | Package basque_grammars is already up-to-date!\n",
|
| 551 |
+
"[nltk_data] | Downloading package bcp47 to\n",
|
| 552 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 553 |
+
"[nltk_data] | Package bcp47 is already up-to-date!\n",
|
| 554 |
+
"[nltk_data] | Downloading package biocreative_ppi to\n",
|
| 555 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 556 |
+
"[nltk_data] | Package biocreative_ppi is already up-to-date!\n",
|
| 557 |
+
"[nltk_data] | Downloading package bllip_wsj_no_aux to\n",
|
| 558 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 559 |
+
"[nltk_data] | Package bllip_wsj_no_aux is already up-to-date!\n",
|
| 560 |
+
"[nltk_data] | Downloading package book_grammars to\n",
|
| 561 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 562 |
+
"[nltk_data] | Package book_grammars is already up-to-date!\n",
|
| 563 |
+
"[nltk_data] | Downloading package brown to\n",
|
| 564 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 565 |
+
"[nltk_data] | Package brown is already up-to-date!\n",
|
| 566 |
+
"[nltk_data] | Downloading package brown_tei to\n",
|
| 567 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 568 |
+
"[nltk_data] | Package brown_tei is already up-to-date!\n",
|
| 569 |
+
"[nltk_data] | Downloading package cess_cat to\n",
|
| 570 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 571 |
+
"[nltk_data] | Package cess_cat is already up-to-date!\n",
|
| 572 |
+
"[nltk_data] | Downloading package cess_esp to\n",
|
| 573 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 574 |
+
"[nltk_data] | Package cess_esp is already up-to-date!\n",
|
| 575 |
+
"[nltk_data] | Downloading package chat80 to\n",
|
| 576 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 577 |
+
"[nltk_data] | Package chat80 is already up-to-date!\n",
|
| 578 |
+
"[nltk_data] | Downloading package city_database to\n",
|
| 579 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 580 |
+
"[nltk_data] | Package city_database is already up-to-date!\n",
|
| 581 |
+
"[nltk_data] | Downloading package cmudict to\n",
|
| 582 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 583 |
+
"[nltk_data] | Package cmudict is already up-to-date!\n",
|
| 584 |
+
"[nltk_data] | Downloading package comparative_sentences to\n",
|
| 585 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 586 |
+
"[nltk_data] | Package comparative_sentences is already up-to-\n",
|
| 587 |
+
"[nltk_data] | date!\n",
|
| 588 |
+
"[nltk_data] | Downloading package comtrans to\n",
|
| 589 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 590 |
+
"[nltk_data] | Package comtrans is already up-to-date!\n",
|
| 591 |
+
"[nltk_data] | Downloading package conll2000 to\n",
|
| 592 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 593 |
+
"[nltk_data] | Package conll2000 is already up-to-date!\n",
|
| 594 |
+
"[nltk_data] | Downloading package conll2002 to\n",
|
| 595 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 596 |
+
"[nltk_data] | Package conll2002 is already up-to-date!\n",
|
| 597 |
+
"[nltk_data] | Downloading package conll2007 to\n",
|
| 598 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 599 |
+
"[nltk_data] | Package conll2007 is already up-to-date!\n",
|
| 600 |
+
"[nltk_data] | Downloading package crubadan to\n",
|
| 601 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 602 |
+
"[nltk_data] | Package crubadan is already up-to-date!\n",
|
| 603 |
+
"[nltk_data] | Downloading package dependency_treebank to\n",
|
| 604 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 605 |
+
"[nltk_data] | Package dependency_treebank is already up-to-date!\n",
|
| 606 |
+
"[nltk_data] | Downloading package dolch to\n",
|
| 607 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 608 |
+
"[nltk_data] | Package dolch is already up-to-date!\n",
|
| 609 |
+
"[nltk_data] | Downloading package europarl_raw to\n",
|
| 610 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 611 |
+
"[nltk_data] | Package europarl_raw is already up-to-date!\n",
|
| 612 |
+
"[nltk_data] | Downloading package extended_omw to\n",
|
| 613 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 614 |
+
"[nltk_data] | Package extended_omw is already up-to-date!\n",
|
| 615 |
+
"[nltk_data] | Downloading package floresta to\n",
|
| 616 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 617 |
+
"[nltk_data] | Package floresta is already up-to-date!\n",
|
| 618 |
+
"[nltk_data] | Downloading package framenet_v15 to\n",
|
| 619 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 620 |
+
"[nltk_data] | Package framenet_v15 is already up-to-date!\n",
|
| 621 |
+
"[nltk_data] | Downloading package framenet_v17 to\n",
|
| 622 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 623 |
+
"[nltk_data] | Package framenet_v17 is already up-to-date!\n",
|
| 624 |
+
"[nltk_data] | Downloading package gazetteers to\n",
|
| 625 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 626 |
+
"[nltk_data] | Package gazetteers is already up-to-date!\n",
|
| 627 |
+
"[nltk_data] | Downloading package genesis to\n",
|
| 628 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 629 |
+
"[nltk_data] | Package genesis is already up-to-date!\n",
|
| 630 |
+
"[nltk_data] | Downloading package gutenberg to\n",
|
| 631 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 632 |
+
"[nltk_data] | Package gutenberg is already up-to-date!\n",
|
| 633 |
+
"[nltk_data] | Downloading package ieer to\n",
|
| 634 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 635 |
+
"[nltk_data] | Package ieer is already up-to-date!\n",
|
| 636 |
+
"[nltk_data] | Downloading package inaugural to\n",
|
| 637 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 638 |
+
"[nltk_data] | Unzipping corpora\\inaugural.zip.\n",
|
| 639 |
+
"[nltk_data] | Downloading package indian to\n",
|
| 640 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 641 |
+
"[nltk_data] | Package indian is already up-to-date!\n",
|
| 642 |
+
"[nltk_data] | Downloading package jeita to\n",
|
| 643 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 644 |
+
"[nltk_data] | Package jeita is already up-to-date!\n",
|
| 645 |
+
"[nltk_data] | Downloading package kimmo to\n",
|
| 646 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 647 |
+
"[nltk_data] | Package kimmo is already up-to-date!\n",
|
| 648 |
+
"[nltk_data] | Downloading package knbc to\n",
|
| 649 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 650 |
+
"[nltk_data] | Package knbc is already up-to-date!\n",
|
| 651 |
+
"[nltk_data] | Downloading package large_grammars to\n",
|
| 652 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 653 |
+
"[nltk_data] | Package large_grammars is already up-to-date!\n",
|
| 654 |
+
"[nltk_data] | Downloading package lin_thesaurus to\n",
|
| 655 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 656 |
+
"[nltk_data] | Package lin_thesaurus is already up-to-date!\n",
|
| 657 |
+
"[nltk_data] | Downloading package mac_morpho to\n",
|
| 658 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 659 |
+
"[nltk_data] | Package mac_morpho is already up-to-date!\n",
|
| 660 |
+
"[nltk_data] | Downloading package machado to\n",
|
| 661 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 662 |
+
"[nltk_data] | Package machado is already up-to-date!\n",
|
| 663 |
+
"[nltk_data] | Downloading package masc_tagged to\n",
|
| 664 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 665 |
+
"[nltk_data] | Package masc_tagged is already up-to-date!\n",
|
| 666 |
+
"[nltk_data] | Downloading package maxent_ne_chunker to\n",
|
| 667 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 668 |
+
"[nltk_data] | Package maxent_ne_chunker is already up-to-date!\n",
|
| 669 |
+
"[nltk_data] | Downloading package maxent_ne_chunker_tab to\n",
|
| 670 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 671 |
+
"[nltk_data] | Package maxent_ne_chunker_tab is already up-to-\n",
|
| 672 |
+
"[nltk_data] | date!\n",
|
| 673 |
+
"[nltk_data] | Downloading package maxent_treebank_pos_tagger to\n",
|
| 674 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 675 |
+
"[nltk_data] | Package maxent_treebank_pos_tagger is already up-\n",
|
| 676 |
+
"[nltk_data] | to-date!\n",
|
| 677 |
+
"[nltk_data] | Downloading package maxent_treebank_pos_tagger_tab to\n",
|
| 678 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 679 |
+
"[nltk_data] | Package maxent_treebank_pos_tagger_tab is already\n",
|
| 680 |
+
"[nltk_data] | up-to-date!\n",
|
| 681 |
+
"[nltk_data] | Downloading package moses_sample to\n",
|
| 682 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 683 |
+
"[nltk_data] | Package moses_sample is already up-to-date!\n",
|
| 684 |
+
"[nltk_data] | Downloading package movie_reviews to\n",
|
| 685 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 686 |
+
"[nltk_data] | Package movie_reviews is already up-to-date!\n",
|
| 687 |
+
"[nltk_data] | Downloading package mte_teip5 to\n",
|
| 688 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 689 |
+
"[nltk_data] | Package mte_teip5 is already up-to-date!\n",
|
| 690 |
+
"[nltk_data] | Downloading package mwa_ppdb to\n",
|
| 691 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 692 |
+
"[nltk_data] | Package mwa_ppdb is already up-to-date!\n",
|
| 693 |
+
"[nltk_data] | Downloading package names to\n",
|
| 694 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 695 |
+
"[nltk_data] | Package names is already up-to-date!\n",
|
| 696 |
+
"[nltk_data] | Downloading package nombank.1.0 to\n",
|
| 697 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 698 |
+
"[nltk_data] | Package nombank.1.0 is already up-to-date!\n",
|
| 699 |
+
"[nltk_data] | Downloading package nonbreaking_prefixes to\n",
|
| 700 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 701 |
+
"[nltk_data] | Package nonbreaking_prefixes is already up-to-date!\n",
|
| 702 |
+
"[nltk_data] | Downloading package nps_chat to\n",
|
| 703 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 704 |
+
"[nltk_data] | Package nps_chat is already up-to-date!\n",
|
| 705 |
+
"[nltk_data] | Downloading package omw to\n",
|
| 706 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 707 |
+
"[nltk_data] | Package omw is already up-to-date!\n",
|
| 708 |
+
"[nltk_data] | Downloading package omw-1.4 to\n",
|
| 709 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 710 |
+
"[nltk_data] | Package omw-1.4 is already up-to-date!\n",
|
| 711 |
+
"[nltk_data] | Downloading package opinion_lexicon to\n",
|
| 712 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 713 |
+
"[nltk_data] | Package opinion_lexicon is already up-to-date!\n",
|
| 714 |
+
"[nltk_data] | Downloading package panlex_swadesh to\n",
|
| 715 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 716 |
+
"[nltk_data] | Package panlex_swadesh is already up-to-date!\n",
|
| 717 |
+
"[nltk_data] | Downloading package paradigms to\n",
|
| 718 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 719 |
+
"[nltk_data] | Package paradigms is already up-to-date!\n",
|
| 720 |
+
"[nltk_data] | Downloading package pe08 to\n",
|
| 721 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 722 |
+
"[nltk_data] | Package pe08 is already up-to-date!\n",
|
| 723 |
+
"[nltk_data] | Downloading package perluniprops to\n",
|
| 724 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 725 |
+
"[nltk_data] | Package perluniprops is already up-to-date!\n",
|
| 726 |
+
"[nltk_data] | Downloading package pil to\n",
|
| 727 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 728 |
+
"[nltk_data] | Package pil is already up-to-date!\n",
|
| 729 |
+
"[nltk_data] | Downloading package pl196x to\n",
|
| 730 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 731 |
+
"[nltk_data] | Package pl196x is already up-to-date!\n",
|
| 732 |
+
"[nltk_data] | Downloading package porter_test to\n",
|
| 733 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 734 |
+
"[nltk_data] | Package porter_test is already up-to-date!\n",
|
| 735 |
+
"[nltk_data] | Downloading package ppattach to\n",
|
| 736 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 737 |
+
"[nltk_data] | Package ppattach is already up-to-date!\n",
|
| 738 |
+
"[nltk_data] | Downloading package problem_reports to\n",
|
| 739 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 740 |
+
"[nltk_data] | Package problem_reports is already up-to-date!\n",
|
| 741 |
+
"[nltk_data] | Downloading package product_reviews_1 to\n",
|
| 742 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 743 |
+
"[nltk_data] | Package product_reviews_1 is already up-to-date!\n",
|
| 744 |
+
"[nltk_data] | Downloading package product_reviews_2 to\n",
|
| 745 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 746 |
+
"[nltk_data] | Package product_reviews_2 is already up-to-date!\n",
|
| 747 |
+
"[nltk_data] | Downloading package propbank to\n",
|
| 748 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 749 |
+
"[nltk_data] | Package propbank is already up-to-date!\n",
|
| 750 |
+
"[nltk_data] | Downloading package pros_cons to\n",
|
| 751 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 752 |
+
"[nltk_data] | Package pros_cons is already up-to-date!\n",
|
| 753 |
+
"[nltk_data] | Downloading package ptb to\n",
|
| 754 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 755 |
+
"[nltk_data] | Package ptb is already up-to-date!\n",
|
| 756 |
+
"[nltk_data] | Downloading package punkt to\n",
|
| 757 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 758 |
+
"[nltk_data] | Package punkt is already up-to-date!\n",
|
| 759 |
+
"[nltk_data] | Downloading package punkt_tab to\n",
|
| 760 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 761 |
+
"[nltk_data] | Unzipping tokenizers\\punkt_tab.zip.\n",
|
| 762 |
+
"[nltk_data] | Downloading package qc to\n",
|
| 763 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 764 |
+
"[nltk_data] | Package qc is already up-to-date!\n",
|
| 765 |
+
"[nltk_data] | Downloading package reuters to\n",
|
| 766 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 767 |
+
"[nltk_data] | Package reuters is already up-to-date!\n",
|
| 768 |
+
"[nltk_data] | Downloading package rslp to\n",
|
| 769 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 770 |
+
"[nltk_data] | Package rslp is already up-to-date!\n",
|
| 771 |
+
"[nltk_data] | Downloading package rte to\n",
|
| 772 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 773 |
+
"[nltk_data] | Package rte is already up-to-date!\n",
|
| 774 |
+
"[nltk_data] | Downloading package sample_grammars to\n",
|
| 775 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 776 |
+
"[nltk_data] | Package sample_grammars is already up-to-date!\n",
|
| 777 |
+
"[nltk_data] | Downloading package semcor to\n",
|
| 778 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 779 |
+
"[nltk_data] | Package semcor is already up-to-date!\n",
|
| 780 |
+
"[nltk_data] | Downloading package senseval to\n",
|
| 781 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 782 |
+
"[nltk_data] | Package senseval is already up-to-date!\n",
|
| 783 |
+
"[nltk_data] | Downloading package sentence_polarity to\n",
|
| 784 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 785 |
+
"[nltk_data] | Package sentence_polarity is already up-to-date!\n",
|
| 786 |
+
"[nltk_data] | Downloading package sentiwordnet to\n",
|
| 787 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 788 |
+
"[nltk_data] | Package sentiwordnet is already up-to-date!\n",
|
| 789 |
+
"[nltk_data] | Downloading package shakespeare to\n",
|
| 790 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 791 |
+
"[nltk_data] | Package shakespeare is already up-to-date!\n",
|
| 792 |
+
"[nltk_data] | Downloading package sinica_treebank to\n",
|
| 793 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 794 |
+
"[nltk_data] | Package sinica_treebank is already up-to-date!\n",
|
| 795 |
+
"[nltk_data] | Downloading package smultron to\n",
|
| 796 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 797 |
+
"[nltk_data] | Package smultron is already up-to-date!\n",
|
| 798 |
+
"[nltk_data] | Downloading package snowball_data to\n",
|
| 799 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 800 |
+
"[nltk_data] | Package snowball_data is already up-to-date!\n",
|
| 801 |
+
"[nltk_data] | Downloading package spanish_grammars to\n",
|
| 802 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 803 |
+
"[nltk_data] | Package spanish_grammars is already up-to-date!\n",
|
| 804 |
+
"[nltk_data] | Downloading package state_union to\n",
|
| 805 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 806 |
+
"[nltk_data] | Package state_union is already up-to-date!\n",
|
| 807 |
+
"[nltk_data] | Downloading package stopwords to\n",
|
| 808 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 809 |
+
"[nltk_data] | Package stopwords is already up-to-date!\n",
|
| 810 |
+
"[nltk_data] | Downloading package subjectivity to\n",
|
| 811 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 812 |
+
"[nltk_data] | Package subjectivity is already up-to-date!\n",
|
| 813 |
+
"[nltk_data] | Downloading package swadesh to\n",
|
| 814 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 815 |
+
"[nltk_data] | Package swadesh is already up-to-date!\n",
|
| 816 |
+
"[nltk_data] | Downloading package switchboard to\n",
|
| 817 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 818 |
+
"[nltk_data] | Package switchboard is already up-to-date!\n",
|
| 819 |
+
"[nltk_data] | Downloading package tagsets to\n",
|
| 820 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 821 |
+
"[nltk_data] | Package tagsets is already up-to-date!\n",
|
| 822 |
+
"[nltk_data] | Downloading package tagsets_json to\n",
|
| 823 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 824 |
+
"[nltk_data] | Package tagsets_json is already up-to-date!\n",
|
| 825 |
+
"[nltk_data] | Downloading package timit to\n",
|
| 826 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 827 |
+
"[nltk_data] | Package timit is already up-to-date!\n",
|
| 828 |
+
"[nltk_data] | Downloading package toolbox to\n",
|
| 829 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 830 |
+
"[nltk_data] | Package toolbox is already up-to-date!\n",
|
| 831 |
+
"[nltk_data] | Downloading package treebank to\n",
|
| 832 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 833 |
+
"[nltk_data] | Package treebank is already up-to-date!\n",
|
| 834 |
+
"[nltk_data] | Downloading package twitter_samples to\n",
|
| 835 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 836 |
+
"[nltk_data] | Package twitter_samples is already up-to-date!\n",
|
| 837 |
+
"[nltk_data] | Downloading package udhr to\n",
|
| 838 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 839 |
+
"[nltk_data] | Package udhr is already up-to-date!\n",
|
| 840 |
+
"[nltk_data] | Downloading package udhr2 to\n",
|
| 841 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 842 |
+
"[nltk_data] | Package udhr2 is already up-to-date!\n",
|
| 843 |
+
"[nltk_data] | Downloading package unicode_samples to\n",
|
| 844 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 845 |
+
"[nltk_data] | Package unicode_samples is already up-to-date!\n",
|
| 846 |
+
"[nltk_data] | Downloading package universal_tagset to\n",
|
| 847 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 848 |
+
"[nltk_data] | Package universal_tagset is already up-to-date!\n",
|
| 849 |
+
"[nltk_data] | Downloading package universal_treebanks_v20 to\n",
|
| 850 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 851 |
+
"[nltk_data] | Package universal_treebanks_v20 is already up-to-\n",
|
| 852 |
+
"[nltk_data] | date!\n",
|
| 853 |
+
"[nltk_data] | Downloading package vader_lexicon to\n",
|
| 854 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 855 |
+
"[nltk_data] | Package vader_lexicon is already up-to-date!\n",
|
| 856 |
+
"[nltk_data] | Downloading package verbnet to\n",
|
| 857 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 858 |
+
"[nltk_data] | Package verbnet is already up-to-date!\n",
|
| 859 |
+
"[nltk_data] | Downloading package verbnet3 to\n",
|
| 860 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 861 |
+
"[nltk_data] | Package verbnet3 is already up-to-date!\n",
|
| 862 |
+
"[nltk_data] | Downloading package webtext to\n",
|
| 863 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 864 |
+
"[nltk_data] | Package webtext is already up-to-date!\n",
|
| 865 |
+
"[nltk_data] | Downloading package wmt15_eval to\n",
|
| 866 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 867 |
+
"[nltk_data] | Package wmt15_eval is already up-to-date!\n",
|
| 868 |
+
"[nltk_data] | Downloading package word2vec_sample to\n",
|
| 869 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 870 |
+
"[nltk_data] | Package word2vec_sample is already up-to-date!\n",
|
| 871 |
+
"[nltk_data] | Downloading package wordnet to\n",
|
| 872 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 873 |
+
"[nltk_data] | Package wordnet is already up-to-date!\n",
|
| 874 |
+
"[nltk_data] | Downloading package wordnet2021 to\n",
|
| 875 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 876 |
+
"[nltk_data] | Package wordnet2021 is already up-to-date!\n",
|
| 877 |
+
"[nltk_data] | Downloading package wordnet2022 to\n",
|
| 878 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 879 |
+
"[nltk_data] | Package wordnet2022 is already up-to-date!\n",
|
| 880 |
+
"[nltk_data] | Downloading package wordnet31 to\n",
|
| 881 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 882 |
+
"[nltk_data] | Package wordnet31 is already up-to-date!\n",
|
| 883 |
+
"[nltk_data] | Downloading package wordnet_ic to\n",
|
| 884 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 885 |
+
"[nltk_data] | Package wordnet_ic is already up-to-date!\n",
|
| 886 |
+
"[nltk_data] | Downloading package words to\n",
|
| 887 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 888 |
+
"[nltk_data] | Package words is already up-to-date!\n",
|
| 889 |
+
"[nltk_data] | Downloading package ycoe to\n",
|
| 890 |
+
"[nltk_data] | C:\\Users\\LAPSHOP\\AppData\\Roaming\\nltk_data...\n",
|
| 891 |
+
"[nltk_data] | Package ycoe is already up-to-date!\n",
|
| 892 |
+
"[nltk_data] | \n",
|
| 893 |
+
"[nltk_data] Done downloading collection all\n"
|
| 894 |
+
]
|
| 895 |
+
},
|
| 896 |
+
{
|
| 897 |
+
"data": {
|
| 898 |
+
"text/plain": [
|
| 899 |
+
"True"
|
| 900 |
+
]
|
| 901 |
+
},
|
| 902 |
+
"execution_count": 14,
|
| 903 |
+
"metadata": {},
|
| 904 |
+
"output_type": "execute_result"
|
| 905 |
+
}
|
| 906 |
+
],
|
| 907 |
+
"source": [
|
| 908 |
+
"import nltk\n",
|
| 909 |
+
"nltk.download('all')"
|
| 910 |
+
]
|
| 911 |
+
},
|
| 912 |
+
{
|
| 913 |
+
"cell_type": "code",
|
| 914 |
+
"execution_count": 14,
|
| 915 |
+
"metadata": {},
|
| 916 |
+
"outputs": [],
|
| 917 |
+
"source": [
|
| 918 |
+
"'''\n",
|
| 919 |
+
"Job Id is 1017340707950150\n",
|
| 920 |
+
"workplace is Panama City Panama\n",
|
| 921 |
+
"working_mode is Contract\n",
|
| 922 |
+
"salary is 69500.0\n",
|
| 923 |
+
"position is Procurement Manager\n",
|
| 924 |
+
"job_role_and_duties is Promote supplier diversity initiatives and inclusion. Identify and onboard diverse suppliers. Monitor compliance with diversity goals and regulations. Supplier Diversity ManagerPromote diversity and inclusion in the supply chain, manage supplier diversity programs, and assess supplier performance.\n",
|
| 925 |
+
"requisite_skill is Supplier diversity programs Diversity and inclusion initiatives Supplier assessment and certification Data collection and reporting Vendor outreach and engagement Strategic planning Communication skills Relationship building Attention to diversity and inclusion principles 5 to 10 Years BBA\n",
|
| 926 |
+
"offer_details is {'Transportation Benefits, Professional Development, Bonuses and Incentive Programs, Profit-Sharing, Employee Discounts'}\n",
|
| 927 |
+
"'''\n",
|
| 928 |
+
"# convert workplace to lowercase\n",
|
| 929 |
+
"FinalJobs[\"workplace\"] = FinalJobs[\"workplace\"].str.lower()\n",
|
| 930 |
+
"# convert working_mode to lowercase\n",
|
| 931 |
+
"FinalJobs[\"working_mode\"] = FinalJobs[\"working_mode\"].str.lower()\n",
|
| 932 |
+
"# convert position to lowercase\n",
|
| 933 |
+
"FinalJobs[\"position\"] = FinalJobs[\"position\"].str.lower()\n",
|
| 934 |
+
"# convert job_role_and_duties to lowercase and remove extra spaces\n",
|
| 935 |
+
"FinalJobs[\"job_role_and_duties\"] = FinalJobs[\"job_role_and_duties\"].str.lower().str.strip()\n",
|
| 936 |
+
"# convert requisite_skill to lowercase and remove extra spaces\n",
|
| 937 |
+
"FinalJobs[\"requisite_skill\"] = FinalJobs[\"requisite_skill\"].str.lower().str.strip()\n",
|
| 938 |
+
"# convert offer_details to lowercase and remove extra spaces and curly brackets\n",
|
| 939 |
+
"FinalJobs[\"offer_details\"] = FinalJobs[\"offer_details\"].str.lower().str.strip(\"{}\")\n"
|
| 940 |
+
]
|
| 941 |
+
},
|
| 942 |
+
{
|
| 943 |
+
"cell_type": "code",
|
| 944 |
+
"execution_count": 15,
|
| 945 |
+
"metadata": {},
|
| 946 |
+
"outputs": [
|
| 947 |
+
{
|
| 948 |
+
"data": {
|
| 949 |
+
"text/html": [
|
| 950 |
+
"<div>\n",
|
| 951 |
+
"<style scoped>\n",
|
| 952 |
+
" .dataframe tbody tr th:only-of-type {\n",
|
| 953 |
+
" vertical-align: middle;\n",
|
| 954 |
+
" }\n",
|
| 955 |
+
"\n",
|
| 956 |
+
" .dataframe tbody tr th {\n",
|
| 957 |
+
" vertical-align: top;\n",
|
| 958 |
+
" }\n",
|
| 959 |
+
"\n",
|
| 960 |
+
" .dataframe thead th {\n",
|
| 961 |
+
" text-align: right;\n",
|
| 962 |
+
" }\n",
|
| 963 |
+
"</style>\n",
|
| 964 |
+
"<table border=\"1\" class=\"dataframe\">\n",
|
| 965 |
+
" <thead>\n",
|
| 966 |
+
" <tr style=\"text-align: right;\">\n",
|
| 967 |
+
" <th></th>\n",
|
| 968 |
+
" <th>Job Id</th>\n",
|
| 969 |
+
" <th>workplace</th>\n",
|
| 970 |
+
" <th>working_mode</th>\n",
|
| 971 |
+
" <th>salary</th>\n",
|
| 972 |
+
" <th>position</th>\n",
|
| 973 |
+
" <th>job_role_and_duties</th>\n",
|
| 974 |
+
" <th>requisite_skill</th>\n",
|
| 975 |
+
" <th>offer_details</th>\n",
|
| 976 |
+
" </tr>\n",
|
| 977 |
+
" </thead>\n",
|
| 978 |
+
" <tbody>\n",
|
| 979 |
+
" <tr>\n",
|
| 980 |
+
" <th>3184</th>\n",
|
| 981 |
+
" <td>2380596380494743</td>\n",
|
| 982 |
+
" <td>valletta malta</td>\n",
|
| 983 |
+
" <td>part-time</td>\n",
|
| 984 |
+
" <td>80500.0</td>\n",
|
| 985 |
+
" <td>network technician</td>\n",
|
| 986 |
+
" <td>focus on network security, implementing measur...</td>\n",
|
| 987 |
+
" <td>network security cybersecurity intrusion detec...</td>\n",
|
| 988 |
+
" <td>'childcare assistance, paid time off (pto), re...</td>\n",
|
| 989 |
+
" </tr>\n",
|
| 990 |
+
" </tbody>\n",
|
| 991 |
+
"</table>\n",
|
| 992 |
+
"</div>"
|
| 993 |
+
],
|
| 994 |
+
"text/plain": [
|
| 995 |
+
" Job Id workplace working_mode salary \\\n",
|
| 996 |
+
"3184 2380596380494743 valletta malta part-time 80500.0 \n",
|
| 997 |
+
"\n",
|
| 998 |
+
" position job_role_and_duties \\\n",
|
| 999 |
+
"3184 network technician focus on network security, implementing measur... \n",
|
| 1000 |
+
"\n",
|
| 1001 |
+
" requisite_skill \\\n",
|
| 1002 |
+
"3184 network security cybersecurity intrusion detec... \n",
|
| 1003 |
+
"\n",
|
| 1004 |
+
" offer_details \n",
|
| 1005 |
+
"3184 'childcare assistance, paid time off (pto), re... "
|
| 1006 |
+
]
|
| 1007 |
+
},
|
| 1008 |
+
"execution_count": 15,
|
| 1009 |
+
"metadata": {},
|
| 1010 |
+
"output_type": "execute_result"
|
| 1011 |
+
}
|
| 1012 |
+
],
|
| 1013 |
+
"source": [
|
| 1014 |
+
"FinalJobs.sample(1)"
|
| 1015 |
+
]
|
| 1016 |
+
},
|
| 1017 |
+
{
|
| 1018 |
+
"cell_type": "code",
|
| 1019 |
+
"execution_count": 16,
|
| 1020 |
+
"metadata": {},
|
| 1021 |
+
"outputs": [],
|
| 1022 |
+
"source": [
|
| 1023 |
+
"import re\n",
|
| 1024 |
+
"# Remove special characters from \"job_role_and_duties\" and \"requisite_skill\" and offer_details\n",
|
| 1025 |
+
"def remove_special_characters(text):\n",
|
| 1026 |
+
" return re.sub(r\"[^a-zA-Z0-9 ]\", \"\", text)\n",
|
| 1027 |
+
"\n",
|
| 1028 |
+
"FinalJobs[\"job_role_and_duties\"] = FinalJobs[\"job_role_and_duties\"].apply(remove_special_characters)\n",
|
| 1029 |
+
"FinalJobs[\"requisite_skill\"] = FinalJobs[\"requisite_skill\"].apply(remove_special_characters)\n",
|
| 1030 |
+
"FinalJobs[\"offer_details\"] = FinalJobs[\"offer_details\"].apply(remove_special_characters)\n"
|
| 1031 |
+
]
|
| 1032 |
+
},
|
| 1033 |
+
{
|
| 1034 |
+
"cell_type": "code",
|
| 1035 |
+
"execution_count": 17,
|
| 1036 |
+
"metadata": {},
|
| 1037 |
+
"outputs": [
|
| 1038 |
+
{
|
| 1039 |
+
"data": {
|
| 1040 |
+
"text/html": [
|
| 1041 |
+
"<div>\n",
|
| 1042 |
+
"<style scoped>\n",
|
| 1043 |
+
" .dataframe tbody tr th:only-of-type {\n",
|
| 1044 |
+
" vertical-align: middle;\n",
|
| 1045 |
+
" }\n",
|
| 1046 |
+
"\n",
|
| 1047 |
+
" .dataframe tbody tr th {\n",
|
| 1048 |
+
" vertical-align: top;\n",
|
| 1049 |
+
" }\n",
|
| 1050 |
+
"\n",
|
| 1051 |
+
" .dataframe thead th {\n",
|
| 1052 |
+
" text-align: right;\n",
|
| 1053 |
+
" }\n",
|
| 1054 |
+
"</style>\n",
|
| 1055 |
+
"<table border=\"1\" class=\"dataframe\">\n",
|
| 1056 |
+
" <thead>\n",
|
| 1057 |
+
" <tr style=\"text-align: right;\">\n",
|
| 1058 |
+
" <th></th>\n",
|
| 1059 |
+
" <th>Job Id</th>\n",
|
| 1060 |
+
" <th>workplace</th>\n",
|
| 1061 |
+
" <th>working_mode</th>\n",
|
| 1062 |
+
" <th>salary</th>\n",
|
| 1063 |
+
" <th>position</th>\n",
|
| 1064 |
+
" <th>job_role_and_duties</th>\n",
|
| 1065 |
+
" <th>requisite_skill</th>\n",
|
| 1066 |
+
" <th>offer_details</th>\n",
|
| 1067 |
+
" </tr>\n",
|
| 1068 |
+
" </thead>\n",
|
| 1069 |
+
" <tbody>\n",
|
| 1070 |
+
" <tr>\n",
|
| 1071 |
+
" <th>9327</th>\n",
|
| 1072 |
+
" <td>2334880320049787</td>\n",
|
| 1073 |
+
" <td>manama bahrain</td>\n",
|
| 1074 |
+
" <td>intern</td>\n",
|
| 1075 |
+
" <td>93500.0</td>\n",
|
| 1076 |
+
" <td>research analyst</td>\n",
|
| 1077 |
+
" <td>conduct research in social sciences gathering ...</td>\n",
|
| 1078 |
+
" <td>social science research methods qualitative an...</td>\n",
|
| 1079 |
+
" <td>flexible spending accounts fsas relocation ass...</td>\n",
|
| 1080 |
+
" </tr>\n",
|
| 1081 |
+
" </tbody>\n",
|
| 1082 |
+
"</table>\n",
|
| 1083 |
+
"</div>"
|
| 1084 |
+
],
|
| 1085 |
+
"text/plain": [
|
| 1086 |
+
" Job Id workplace working_mode salary \\\n",
|
| 1087 |
+
"9327 2334880320049787 manama bahrain intern 93500.0 \n",
|
| 1088 |
+
"\n",
|
| 1089 |
+
" position job_role_and_duties \\\n",
|
| 1090 |
+
"9327 research analyst conduct research in social sciences gathering ... \n",
|
| 1091 |
+
"\n",
|
| 1092 |
+
" requisite_skill \\\n",
|
| 1093 |
+
"9327 social science research methods qualitative an... \n",
|
| 1094 |
+
"\n",
|
| 1095 |
+
" offer_details \n",
|
| 1096 |
+
"9327 flexible spending accounts fsas relocation ass... "
|
| 1097 |
+
]
|
| 1098 |
+
},
|
| 1099 |
+
"execution_count": 17,
|
| 1100 |
+
"metadata": {},
|
| 1101 |
+
"output_type": "execute_result"
|
| 1102 |
+
}
|
| 1103 |
+
],
|
| 1104 |
+
"source": [
|
| 1105 |
+
"FinalJobs.sample(1)"
|
| 1106 |
+
]
|
| 1107 |
+
},
|
| 1108 |
+
{
|
| 1109 |
+
"cell_type": "code",
|
| 1110 |
+
"execution_count": 18,
|
| 1111 |
+
"metadata": {},
|
| 1112 |
+
"outputs": [
|
| 1113 |
+
{
|
| 1114 |
+
"data": {
|
| 1115 |
+
"text/plain": [
|
| 1116 |
+
"(10000, 8)"
|
| 1117 |
+
]
|
| 1118 |
+
},
|
| 1119 |
+
"execution_count": 18,
|
| 1120 |
+
"metadata": {},
|
| 1121 |
+
"output_type": "execute_result"
|
| 1122 |
+
}
|
| 1123 |
+
],
|
| 1124 |
+
"source": [
|
| 1125 |
+
"FinalJobs.to_csv(\"JobsFE.csv\" , index= False)\n",
|
| 1126 |
+
"FinalJobs.shape"
|
| 1127 |
+
]
|
| 1128 |
+
},
|
| 1129 |
+
{
|
| 1130 |
+
"cell_type": "code",
|
| 1131 |
+
"execution_count": null,
|
| 1132 |
+
"metadata": {},
|
| 1133 |
+
"outputs": [],
|
| 1134 |
+
"source": []
|
| 1135 |
+
},
|
| 1136 |
+
{
|
| 1137 |
+
"cell_type": "code",
|
| 1138 |
+
"execution_count": null,
|
| 1139 |
+
"metadata": {},
|
| 1140 |
+
"outputs": [],
|
| 1141 |
+
"source": []
|
| 1142 |
+
}
|
| 1143 |
+
],
|
| 1144 |
+
"metadata": {
|
| 1145 |
+
"kernelspec": {
|
| 1146 |
+
"display_name": "venv",
|
| 1147 |
+
"language": "python",
|
| 1148 |
+
"name": "python3"
|
| 1149 |
+
},
|
| 1150 |
+
"language_info": {
|
| 1151 |
+
"codemirror_mode": {
|
| 1152 |
+
"name": "ipython",
|
| 1153 |
+
"version": 3
|
| 1154 |
+
},
|
| 1155 |
+
"file_extension": ".py",
|
| 1156 |
+
"mimetype": "text/x-python",
|
| 1157 |
+
"name": "python",
|
| 1158 |
+
"nbconvert_exporter": "python",
|
| 1159 |
+
"pygments_lexer": "ipython3",
|
| 1160 |
+
"version": "3.12.4"
|
| 1161 |
+
}
|
| 1162 |
+
},
|
| 1163 |
+
"nbformat": 4,
|
| 1164 |
+
"nbformat_minor": 2
|
| 1165 |
+
}
|
README.md
ADDED
|
@@ -0,0 +1,52 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
# 1) AI-Powered Job Recommendation System
|
| 2 |
+
|
| 3 |
+
This is an AI-driven job recommendation system that analyzes resumes and suggests the most relevant job positions based on skills and experience. The system utilizes **Natural Language Processing (NLP)** and **Semantic Search** to find the best job matches.
|
| 4 |
+
|
| 5 |
+
## 🚀 Features
|
| 6 |
+
- Upload a **PDF resume** for job recommendations
|
| 7 |
+
- **AI-based analysis** using `SentenceTransformer` for job matching
|
| 8 |
+
- **Fast and efficient search** powered by `FAISS`
|
| 9 |
+
- **TF-IDF filtering** to narrow down relevant jobs
|
| 10 |
+
- **Streamlit-powered Web Interface** for easy use
|
| 11 |
+
|
| 12 |
+
## 🛠️ Technologies Used
|
| 13 |
+
- `Python`
|
| 14 |
+
- `Streamlit` (for the UI)
|
| 15 |
+
- `FAISS` (for efficient job matching)
|
| 16 |
+
- `Sentence Transformers` (for embedding resumes and job descriptions)
|
| 17 |
+
- `PyMuPDF` (to extract text from PDF resumes)
|
| 18 |
+
- `scikit-learn` (for TF-IDF filtering)
|
| 19 |
+
|
| 20 |
+
## 📌 How to Run
|
| 21 |
+
1. Clone this repository:
|
| 22 |
+
```sh
|
| 23 |
+
git clone https://github.com/YomnaWaleed/job-recommendation-system-ai.git
|
| 24 |
+
cd job-recommendation-system-ai
|
| 25 |
+
|
| 26 |
+
# 2) Install the dependencies:
|
| 27 |
+
pip install -r requirements.txt
|
| 28 |
+
|
| 29 |
+
# 3) Run the Streamlit app:
|
| 30 |
+
streamlit run streamlit.py
|
| 31 |
+
|
| 32 |
+
# 4) Open the URL shown in the terminal
|
| 33 |
+
(e.g., http://localhost:8501)
|
| 34 |
+
|
| 35 |
+
|
| 36 |
+
|
| 37 |
+
|
| 38 |
+
# 📄 Dataset
|
| 39 |
+
The system uses a CSV file (JobsFE.csv) containing job descriptions, skills, and work details. Ensure this file is present in the project folder.
|
| 40 |
+
|
| 41 |
+
|
| 42 |
+
# 🤖 How It Works
|
| 43 |
+
Resume Processing: Extracts text from the uploaded PDF resume.
|
| 44 |
+
TF-IDF Filtering: Reduces the number of job descriptions for faster and better recommendations.
|
| 45 |
+
Semantic Search: Uses SentenceTransformer embeddings with FAISS for similarity search.
|
| 46 |
+
Top Job Matches: The best job recommendations are displayed on the Streamlit app.
|
| 47 |
+
|
| 48 |
+
|
| 49 |
+
# 📌 Future Improvements
|
| 50 |
+
✅ Support for multiple resume formats (DOCX, TXT)
|
| 51 |
+
✅ Advanced customized filtering based on user preferences
|
| 52 |
+
✅ Integration with LinkedIn job postings
|
model.py
ADDED
|
@@ -0,0 +1,108 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
import string
|
| 2 |
+
import numpy as np
|
| 3 |
+
import faiss
|
| 4 |
+
import pandas as pd
|
| 5 |
+
import torch
|
| 6 |
+
from sentence_transformers import SentenceTransformer
|
| 7 |
+
from sklearn.feature_extraction.text import TfidfVectorizer
|
| 8 |
+
|
| 9 |
+
# ----------------- Load Model -----------------
|
| 10 |
+
MODEL = SentenceTransformer("./paraphrase-MiniLM-L6-v2", device="cpu")
|
| 11 |
+
MODEL = torch.quantization.quantize_dynamic(MODEL, {torch.nn.Linear}, dtype=torch.qint8)
|
| 12 |
+
|
| 13 |
+
|
| 14 |
+
class JobRecommendationSystem:
|
| 15 |
+
def __init__(self, jobs_csv):
|
| 16 |
+
"""Initialize the system and load enriched job data from CSV file."""
|
| 17 |
+
self.jobs_df = pd.read_csv(jobs_csv)
|
| 18 |
+
|
| 19 |
+
# Ensure apply_link exists
|
| 20 |
+
if "apply_link" not in self.jobs_df.columns:
|
| 21 |
+
self.jobs_df["apply_link"] = None
|
| 22 |
+
|
| 23 |
+
# --- Safe column concat ---
|
| 24 |
+
def safe_col(col):
|
| 25 |
+
return self.jobs_df[col].astype(str) + " " if col in self.jobs_df.columns else ""
|
| 26 |
+
|
| 27 |
+
# Build job_text
|
| 28 |
+
self.jobs_df["job_text"] = (
|
| 29 |
+
safe_col("workplace") +
|
| 30 |
+
safe_col("position") +
|
| 31 |
+
safe_col("job_role_and_duties") +
|
| 32 |
+
safe_col("requisite_skill") +
|
| 33 |
+
safe_col("benefits") +
|
| 34 |
+
safe_col("industry_id") +
|
| 35 |
+
safe_col("formatted_work_type") +
|
| 36 |
+
safe_col("work_type") +
|
| 37 |
+
safe_col("formatted_experience_level") +
|
| 38 |
+
safe_col("country") +
|
| 39 |
+
safe_col("state") +
|
| 40 |
+
safe_col("city")
|
| 41 |
+
)
|
| 42 |
+
|
| 43 |
+
self.jobs_texts = self.jobs_df["job_text"].tolist()
|
| 44 |
+
self.job_info = self.jobs_df.copy()
|
| 45 |
+
|
| 46 |
+
# --- Load or compute embeddings ---
|
| 47 |
+
try:
|
| 48 |
+
self.job_embeddings = np.load("job_embeddings.npy").astype(np.float16)
|
| 49 |
+
print("✅ Loaded precomputed embeddings from job_embeddings.npy")
|
| 50 |
+
except FileNotFoundError:
|
| 51 |
+
print("⚠️ job_embeddings.npy not found. Generating embeddings now...")
|
| 52 |
+
self.job_embeddings = MODEL.encode(
|
| 53 |
+
self.jobs_texts,
|
| 54 |
+
convert_to_numpy=True,
|
| 55 |
+
batch_size=32,
|
| 56 |
+
show_progress_bar=True
|
| 57 |
+
).astype(np.float16)
|
| 58 |
+
np.save("job_embeddings.npy", self.job_embeddings)
|
| 59 |
+
print("✅ Saved embeddings to job_embeddings.npy")
|
| 60 |
+
|
| 61 |
+
# --- Build FAISS index (global, on all jobs) ---
|
| 62 |
+
self.dim = self.job_embeddings.shape[1]
|
| 63 |
+
self.index = faiss.IndexFlatIP(self.dim)
|
| 64 |
+
self.index.add(self.job_embeddings.astype(np.float16))
|
| 65 |
+
|
| 66 |
+
# --- Precompute TF-IDF once ---
|
| 67 |
+
self.vectorizer = TfidfVectorizer()
|
| 68 |
+
self.job_tfidf = self.vectorizer.fit_transform(self.jobs_texts)
|
| 69 |
+
|
| 70 |
+
# ----------------- Helpers -----------------
|
| 71 |
+
def clean_text(self, text):
|
| 72 |
+
"""Lowercase, strip punctuation, clean text."""
|
| 73 |
+
return text.lower().translate(str.maketrans("", "", string.punctuation)).strip()
|
| 74 |
+
|
| 75 |
+
def filter_top_jobs(self, resume_text, top_n=500):
|
| 76 |
+
"""Use TF-IDF to preselect most relevant jobs (fast)."""
|
| 77 |
+
resume_vector = self.vectorizer.transform([resume_text])
|
| 78 |
+
similarity_scores = (self.job_tfidf @ resume_vector.T).toarray().flatten()
|
| 79 |
+
top_indices = np.argsort(similarity_scores)[-top_n:]
|
| 80 |
+
return (
|
| 81 |
+
[self.jobs_texts[i] for i in top_indices],
|
| 82 |
+
self.job_info.iloc[top_indices].reset_index(drop=True),
|
| 83 |
+
self.job_embeddings[top_indices],
|
| 84 |
+
)
|
| 85 |
+
|
| 86 |
+
def recommend_jobs(self, resume_text, top_n=20):
|
| 87 |
+
"""Recommend jobs using FAISS similarity search + deduplication."""
|
| 88 |
+
resume_text = self.clean_text(resume_text)
|
| 89 |
+
filtered_jobs_texts, filtered_jobs_df, filtered_embeddings = (
|
| 90 |
+
self.filter_top_jobs(resume_text)
|
| 91 |
+
)
|
| 92 |
+
|
| 93 |
+
# Encode resume
|
| 94 |
+
resume_embedding = MODEL.encode([resume_text], convert_to_numpy=True).astype(np.float16)
|
| 95 |
+
|
| 96 |
+
# Build temporary FAISS index on filtered jobs
|
| 97 |
+
index = faiss.IndexFlatIP(self.dim)
|
| 98 |
+
index.add(filtered_embeddings.astype(np.float16))
|
| 99 |
+
|
| 100 |
+
# Search more than top_n to handle duplicates
|
| 101 |
+
distances, indices = index.search(resume_embedding.astype(np.float16), top_n * 2)
|
| 102 |
+
results = filtered_jobs_df.iloc[indices[0]]
|
| 103 |
+
|
| 104 |
+
# Deduplicate by job_id and return top_n
|
| 105 |
+
results = results.drop_duplicates(subset=["job_id"]).head(top_n)
|
| 106 |
+
recommended_jobs = results.to_dict(orient="records")
|
| 107 |
+
|
| 108 |
+
return {"recommended_jobs": recommended_jobs}
|
node_modules/.bin/gh-pages
ADDED
|
@@ -0,0 +1,16 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
#!/bin/sh
|
| 2 |
+
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
| 3 |
+
|
| 4 |
+
case `uname` in
|
| 5 |
+
*CYGWIN*|*MINGW*|*MSYS*)
|
| 6 |
+
if command -v cygpath > /dev/null 2>&1; then
|
| 7 |
+
basedir=`cygpath -w "$basedir"`
|
| 8 |
+
fi
|
| 9 |
+
;;
|
| 10 |
+
esac
|
| 11 |
+
|
| 12 |
+
if [ -x "$basedir/node" ]; then
|
| 13 |
+
exec "$basedir/node" "$basedir/../gh-pages/bin/gh-pages.js" "$@"
|
| 14 |
+
else
|
| 15 |
+
exec node "$basedir/../gh-pages/bin/gh-pages.js" "$@"
|
| 16 |
+
fi
|
node_modules/.bin/gh-pages-clean
ADDED
|
@@ -0,0 +1,16 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
#!/bin/sh
|
| 2 |
+
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
| 3 |
+
|
| 4 |
+
case `uname` in
|
| 5 |
+
*CYGWIN*|*MINGW*|*MSYS*)
|
| 6 |
+
if command -v cygpath > /dev/null 2>&1; then
|
| 7 |
+
basedir=`cygpath -w "$basedir"`
|
| 8 |
+
fi
|
| 9 |
+
;;
|
| 10 |
+
esac
|
| 11 |
+
|
| 12 |
+
if [ -x "$basedir/node" ]; then
|
| 13 |
+
exec "$basedir/node" "$basedir/../gh-pages/bin/gh-pages-clean.js" "$@"
|
| 14 |
+
else
|
| 15 |
+
exec node "$basedir/../gh-pages/bin/gh-pages-clean.js" "$@"
|
| 16 |
+
fi
|
node_modules/.bin/gh-pages-clean.cmd
ADDED
|
@@ -0,0 +1,17 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
@ECHO off
|
| 2 |
+
GOTO start
|
| 3 |
+
:find_dp0
|
| 4 |
+
SET dp0=%~dp0
|
| 5 |
+
EXIT /b
|
| 6 |
+
:start
|
| 7 |
+
SETLOCAL
|
| 8 |
+
CALL :find_dp0
|
| 9 |
+
|
| 10 |
+
IF EXIST "%dp0%\node.exe" (
|
| 11 |
+
SET "_prog=%dp0%\node.exe"
|
| 12 |
+
) ELSE (
|
| 13 |
+
SET "_prog=node"
|
| 14 |
+
SET PATHEXT=%PATHEXT:;.JS;=;%
|
| 15 |
+
)
|
| 16 |
+
|
| 17 |
+
endLocal & goto #_undefined_# 2>NUL || title %COMSPEC% & "%_prog%" "%dp0%\..\gh-pages\bin\gh-pages-clean.js" %*
|
node_modules/.bin/gh-pages-clean.ps1
ADDED
|
@@ -0,0 +1,28 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
#!/usr/bin/env pwsh
|
| 2 |
+
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
| 3 |
+
|
| 4 |
+
$exe=""
|
| 5 |
+
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
| 6 |
+
# Fix case when both the Windows and Linux builds of Node
|
| 7 |
+
# are installed in the same directory
|
| 8 |
+
$exe=".exe"
|
| 9 |
+
}
|
| 10 |
+
$ret=0
|
| 11 |
+
if (Test-Path "$basedir/node$exe") {
|
| 12 |
+
# Support pipeline input
|
| 13 |
+
if ($MyInvocation.ExpectingInput) {
|
| 14 |
+
$input | & "$basedir/node$exe" "$basedir/../gh-pages/bin/gh-pages-clean.js" $args
|
| 15 |
+
} else {
|
| 16 |
+
& "$basedir/node$exe" "$basedir/../gh-pages/bin/gh-pages-clean.js" $args
|
| 17 |
+
}
|
| 18 |
+
$ret=$LASTEXITCODE
|
| 19 |
+
} else {
|
| 20 |
+
# Support pipeline input
|
| 21 |
+
if ($MyInvocation.ExpectingInput) {
|
| 22 |
+
$input | & "node$exe" "$basedir/../gh-pages/bin/gh-pages-clean.js" $args
|
| 23 |
+
} else {
|
| 24 |
+
& "node$exe" "$basedir/../gh-pages/bin/gh-pages-clean.js" $args
|
| 25 |
+
}
|
| 26 |
+
$ret=$LASTEXITCODE
|
| 27 |
+
}
|
| 28 |
+
exit $ret
|
node_modules/.bin/gh-pages.cmd
ADDED
|
@@ -0,0 +1,17 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
@ECHO off
|
| 2 |
+
GOTO start
|
| 3 |
+
:find_dp0
|
| 4 |
+
SET dp0=%~dp0
|
| 5 |
+
EXIT /b
|
| 6 |
+
:start
|
| 7 |
+
SETLOCAL
|
| 8 |
+
CALL :find_dp0
|
| 9 |
+
|
| 10 |
+
IF EXIST "%dp0%\node.exe" (
|
| 11 |
+
SET "_prog=%dp0%\node.exe"
|
| 12 |
+
) ELSE (
|
| 13 |
+
SET "_prog=node"
|
| 14 |
+
SET PATHEXT=%PATHEXT:;.JS;=;%
|
| 15 |
+
)
|
| 16 |
+
|
| 17 |
+
endLocal & goto #_undefined_# 2>NUL || title %COMSPEC% & "%_prog%" "%dp0%\..\gh-pages\bin\gh-pages.js" %*
|
node_modules/.bin/gh-pages.ps1
ADDED
|
@@ -0,0 +1,28 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
#!/usr/bin/env pwsh
|
| 2 |
+
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
| 3 |
+
|
| 4 |
+
$exe=""
|
| 5 |
+
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
| 6 |
+
# Fix case when both the Windows and Linux builds of Node
|
| 7 |
+
# are installed in the same directory
|
| 8 |
+
$exe=".exe"
|
| 9 |
+
}
|
| 10 |
+
$ret=0
|
| 11 |
+
if (Test-Path "$basedir/node$exe") {
|
| 12 |
+
# Support pipeline input
|
| 13 |
+
if ($MyInvocation.ExpectingInput) {
|
| 14 |
+
$input | & "$basedir/node$exe" "$basedir/../gh-pages/bin/gh-pages.js" $args
|
| 15 |
+
} else {
|
| 16 |
+
& "$basedir/node$exe" "$basedir/../gh-pages/bin/gh-pages.js" $args
|
| 17 |
+
}
|
| 18 |
+
$ret=$LASTEXITCODE
|
| 19 |
+
} else {
|
| 20 |
+
# Support pipeline input
|
| 21 |
+
if ($MyInvocation.ExpectingInput) {
|
| 22 |
+
$input | & "node$exe" "$basedir/../gh-pages/bin/gh-pages.js" $args
|
| 23 |
+
} else {
|
| 24 |
+
& "node$exe" "$basedir/../gh-pages/bin/gh-pages.js" $args
|
| 25 |
+
}
|
| 26 |
+
$ret=$LASTEXITCODE
|
| 27 |
+
}
|
| 28 |
+
exit $ret
|
node_modules/.bin/semver
ADDED
|
@@ -0,0 +1,16 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
#!/bin/sh
|
| 2 |
+
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
| 3 |
+
|
| 4 |
+
case `uname` in
|
| 5 |
+
*CYGWIN*|*MINGW*|*MSYS*)
|
| 6 |
+
if command -v cygpath > /dev/null 2>&1; then
|
| 7 |
+
basedir=`cygpath -w "$basedir"`
|
| 8 |
+
fi
|
| 9 |
+
;;
|
| 10 |
+
esac
|
| 11 |
+
|
| 12 |
+
if [ -x "$basedir/node" ]; then
|
| 13 |
+
exec "$basedir/node" "$basedir/../semver/bin/semver.js" "$@"
|
| 14 |
+
else
|
| 15 |
+
exec node "$basedir/../semver/bin/semver.js" "$@"
|
| 16 |
+
fi
|
node_modules/.bin/semver.cmd
ADDED
|
@@ -0,0 +1,17 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
@ECHO off
|
| 2 |
+
GOTO start
|
| 3 |
+
:find_dp0
|
| 4 |
+
SET dp0=%~dp0
|
| 5 |
+
EXIT /b
|
| 6 |
+
:start
|
| 7 |
+
SETLOCAL
|
| 8 |
+
CALL :find_dp0
|
| 9 |
+
|
| 10 |
+
IF EXIST "%dp0%\node.exe" (
|
| 11 |
+
SET "_prog=%dp0%\node.exe"
|
| 12 |
+
) ELSE (
|
| 13 |
+
SET "_prog=node"
|
| 14 |
+
SET PATHEXT=%PATHEXT:;.JS;=;%
|
| 15 |
+
)
|
| 16 |
+
|
| 17 |
+
endLocal & goto #_undefined_# 2>NUL || title %COMSPEC% & "%_prog%" "%dp0%\..\semver\bin\semver.js" %*
|
node_modules/.bin/semver.ps1
ADDED
|
@@ -0,0 +1,28 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
#!/usr/bin/env pwsh
|
| 2 |
+
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
| 3 |
+
|
| 4 |
+
$exe=""
|
| 5 |
+
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
| 6 |
+
# Fix case when both the Windows and Linux builds of Node
|
| 7 |
+
# are installed in the same directory
|
| 8 |
+
$exe=".exe"
|
| 9 |
+
}
|
| 10 |
+
$ret=0
|
| 11 |
+
if (Test-Path "$basedir/node$exe") {
|
| 12 |
+
# Support pipeline input
|
| 13 |
+
if ($MyInvocation.ExpectingInput) {
|
| 14 |
+
$input | & "$basedir/node$exe" "$basedir/../semver/bin/semver.js" $args
|
| 15 |
+
} else {
|
| 16 |
+
& "$basedir/node$exe" "$basedir/../semver/bin/semver.js" $args
|
| 17 |
+
}
|
| 18 |
+
$ret=$LASTEXITCODE
|
| 19 |
+
} else {
|
| 20 |
+
# Support pipeline input
|
| 21 |
+
if ($MyInvocation.ExpectingInput) {
|
| 22 |
+
$input | & "node$exe" "$basedir/../semver/bin/semver.js" $args
|
| 23 |
+
} else {
|
| 24 |
+
& "node$exe" "$basedir/../semver/bin/semver.js" $args
|
| 25 |
+
}
|
| 26 |
+
$ret=$LASTEXITCODE
|
| 27 |
+
}
|
| 28 |
+
exit $ret
|
node_modules/.package-lock.json
ADDED
|
@@ -0,0 +1,620 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
{
|
| 2 |
+
"name": "job-recommendation-system-ai-main",
|
| 3 |
+
"lockfileVersion": 3,
|
| 4 |
+
"requires": true,
|
| 5 |
+
"packages": {
|
| 6 |
+
"node_modules/@nodelib/fs.scandir": {
|
| 7 |
+
"version": "2.1.5",
|
| 8 |
+
"resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz",
|
| 9 |
+
"integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==",
|
| 10 |
+
"dev": true,
|
| 11 |
+
"license": "MIT",
|
| 12 |
+
"dependencies": {
|
| 13 |
+
"@nodelib/fs.stat": "2.0.5",
|
| 14 |
+
"run-parallel": "^1.1.9"
|
| 15 |
+
},
|
| 16 |
+
"engines": {
|
| 17 |
+
"node": ">= 8"
|
| 18 |
+
}
|
| 19 |
+
},
|
| 20 |
+
"node_modules/@nodelib/fs.stat": {
|
| 21 |
+
"version": "2.0.5",
|
| 22 |
+
"resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz",
|
| 23 |
+
"integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==",
|
| 24 |
+
"dev": true,
|
| 25 |
+
"license": "MIT",
|
| 26 |
+
"engines": {
|
| 27 |
+
"node": ">= 8"
|
| 28 |
+
}
|
| 29 |
+
},
|
| 30 |
+
"node_modules/@nodelib/fs.walk": {
|
| 31 |
+
"version": "1.2.8",
|
| 32 |
+
"resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz",
|
| 33 |
+
"integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==",
|
| 34 |
+
"dev": true,
|
| 35 |
+
"license": "MIT",
|
| 36 |
+
"dependencies": {
|
| 37 |
+
"@nodelib/fs.scandir": "2.1.5",
|
| 38 |
+
"fastq": "^1.6.0"
|
| 39 |
+
},
|
| 40 |
+
"engines": {
|
| 41 |
+
"node": ">= 8"
|
| 42 |
+
}
|
| 43 |
+
},
|
| 44 |
+
"node_modules/array-union": {
|
| 45 |
+
"version": "2.1.0",
|
| 46 |
+
"resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz",
|
| 47 |
+
"integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==",
|
| 48 |
+
"dev": true,
|
| 49 |
+
"license": "MIT",
|
| 50 |
+
"engines": {
|
| 51 |
+
"node": ">=8"
|
| 52 |
+
}
|
| 53 |
+
},
|
| 54 |
+
"node_modules/async": {
|
| 55 |
+
"version": "3.2.6",
|
| 56 |
+
"resolved": "https://registry.npmjs.org/async/-/async-3.2.6.tgz",
|
| 57 |
+
"integrity": "sha512-htCUDlxyyCLMgaM3xXg0C0LW2xqfuQ6p05pCEIsXuyQ+a1koYKTuBMzRNwmybfLgvJDMd0r1LTn4+E0Ti6C2AA==",
|
| 58 |
+
"dev": true,
|
| 59 |
+
"license": "MIT"
|
| 60 |
+
},
|
| 61 |
+
"node_modules/braces": {
|
| 62 |
+
"version": "3.0.3",
|
| 63 |
+
"resolved": "https://registry.npmjs.org/braces/-/braces-3.0.3.tgz",
|
| 64 |
+
"integrity": "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==",
|
| 65 |
+
"dev": true,
|
| 66 |
+
"license": "MIT",
|
| 67 |
+
"dependencies": {
|
| 68 |
+
"fill-range": "^7.1.1"
|
| 69 |
+
},
|
| 70 |
+
"engines": {
|
| 71 |
+
"node": ">=8"
|
| 72 |
+
}
|
| 73 |
+
},
|
| 74 |
+
"node_modules/commander": {
|
| 75 |
+
"version": "13.1.0",
|
| 76 |
+
"resolved": "https://registry.npmjs.org/commander/-/commander-13.1.0.tgz",
|
| 77 |
+
"integrity": "sha512-/rFeCpNJQbhSZjGVwO9RFV3xPqbnERS8MmIQzCtD/zl6gpJuV/bMLuN92oG3F7d8oDEHHRrujSXNUr8fpjntKw==",
|
| 78 |
+
"dev": true,
|
| 79 |
+
"license": "MIT",
|
| 80 |
+
"engines": {
|
| 81 |
+
"node": ">=18"
|
| 82 |
+
}
|
| 83 |
+
},
|
| 84 |
+
"node_modules/commondir": {
|
| 85 |
+
"version": "1.0.1",
|
| 86 |
+
"resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz",
|
| 87 |
+
"integrity": "sha512-W9pAhw0ja1Edb5GVdIF1mjZw/ASI0AlShXM83UUGe2DVr5TdAPEA1OA8m/g8zWp9x6On7gqufY+FatDbC3MDQg==",
|
| 88 |
+
"dev": true,
|
| 89 |
+
"license": "MIT"
|
| 90 |
+
},
|
| 91 |
+
"node_modules/dir-glob": {
|
| 92 |
+
"version": "3.0.1",
|
| 93 |
+
"resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz",
|
| 94 |
+
"integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==",
|
| 95 |
+
"dev": true,
|
| 96 |
+
"license": "MIT",
|
| 97 |
+
"dependencies": {
|
| 98 |
+
"path-type": "^4.0.0"
|
| 99 |
+
},
|
| 100 |
+
"engines": {
|
| 101 |
+
"node": ">=8"
|
| 102 |
+
}
|
| 103 |
+
},
|
| 104 |
+
"node_modules/email-addresses": {
|
| 105 |
+
"version": "5.0.0",
|
| 106 |
+
"resolved": "https://registry.npmjs.org/email-addresses/-/email-addresses-5.0.0.tgz",
|
| 107 |
+
"integrity": "sha512-4OIPYlA6JXqtVn8zpHpGiI7vE6EQOAg16aGnDMIAlZVinnoZ8208tW1hAbjWydgN/4PLTT9q+O1K6AH/vALJGw==",
|
| 108 |
+
"dev": true,
|
| 109 |
+
"license": "MIT"
|
| 110 |
+
},
|
| 111 |
+
"node_modules/escape-string-regexp": {
|
| 112 |
+
"version": "1.0.5",
|
| 113 |
+
"resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz",
|
| 114 |
+
"integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==",
|
| 115 |
+
"dev": true,
|
| 116 |
+
"license": "MIT",
|
| 117 |
+
"engines": {
|
| 118 |
+
"node": ">=0.8.0"
|
| 119 |
+
}
|
| 120 |
+
},
|
| 121 |
+
"node_modules/fast-glob": {
|
| 122 |
+
"version": "3.3.3",
|
| 123 |
+
"resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.3.tgz",
|
| 124 |
+
"integrity": "sha512-7MptL8U0cqcFdzIzwOTHoilX9x5BrNqye7Z/LuC7kCMRio1EMSyqRK3BEAUD7sXRq4iT4AzTVuZdhgQ2TCvYLg==",
|
| 125 |
+
"dev": true,
|
| 126 |
+
"license": "MIT",
|
| 127 |
+
"dependencies": {
|
| 128 |
+
"@nodelib/fs.stat": "^2.0.2",
|
| 129 |
+
"@nodelib/fs.walk": "^1.2.3",
|
| 130 |
+
"glob-parent": "^5.1.2",
|
| 131 |
+
"merge2": "^1.3.0",
|
| 132 |
+
"micromatch": "^4.0.8"
|
| 133 |
+
},
|
| 134 |
+
"engines": {
|
| 135 |
+
"node": ">=8.6.0"
|
| 136 |
+
}
|
| 137 |
+
},
|
| 138 |
+
"node_modules/fastq": {
|
| 139 |
+
"version": "1.19.1",
|
| 140 |
+
"resolved": "https://registry.npmjs.org/fastq/-/fastq-1.19.1.tgz",
|
| 141 |
+
"integrity": "sha512-GwLTyxkCXjXbxqIhTsMI2Nui8huMPtnxg7krajPJAjnEG/iiOS7i+zCtWGZR9G0NBKbXKh6X9m9UIsYX/N6vvQ==",
|
| 142 |
+
"dev": true,
|
| 143 |
+
"license": "ISC",
|
| 144 |
+
"dependencies": {
|
| 145 |
+
"reusify": "^1.0.4"
|
| 146 |
+
}
|
| 147 |
+
},
|
| 148 |
+
"node_modules/filename-reserved-regex": {
|
| 149 |
+
"version": "2.0.0",
|
| 150 |
+
"resolved": "https://registry.npmjs.org/filename-reserved-regex/-/filename-reserved-regex-2.0.0.tgz",
|
| 151 |
+
"integrity": "sha512-lc1bnsSr4L4Bdif8Xb/qrtokGbq5zlsms/CYH8PP+WtCkGNF65DPiQY8vG3SakEdRn8Dlnm+gW/qWKKjS5sZzQ==",
|
| 152 |
+
"dev": true,
|
| 153 |
+
"license": "MIT",
|
| 154 |
+
"engines": {
|
| 155 |
+
"node": ">=4"
|
| 156 |
+
}
|
| 157 |
+
},
|
| 158 |
+
"node_modules/filenamify": {
|
| 159 |
+
"version": "4.3.0",
|
| 160 |
+
"resolved": "https://registry.npmjs.org/filenamify/-/filenamify-4.3.0.tgz",
|
| 161 |
+
"integrity": "sha512-hcFKyUG57yWGAzu1CMt/dPzYZuv+jAJUT85bL8mrXvNe6hWj6yEHEc4EdcgiA6Z3oi1/9wXJdZPXF2dZNgwgOg==",
|
| 162 |
+
"dev": true,
|
| 163 |
+
"license": "MIT",
|
| 164 |
+
"dependencies": {
|
| 165 |
+
"filename-reserved-regex": "^2.0.0",
|
| 166 |
+
"strip-outer": "^1.0.1",
|
| 167 |
+
"trim-repeated": "^1.0.0"
|
| 168 |
+
},
|
| 169 |
+
"engines": {
|
| 170 |
+
"node": ">=8"
|
| 171 |
+
},
|
| 172 |
+
"funding": {
|
| 173 |
+
"url": "https://github.com/sponsors/sindresorhus"
|
| 174 |
+
}
|
| 175 |
+
},
|
| 176 |
+
"node_modules/fill-range": {
|
| 177 |
+
"version": "7.1.1",
|
| 178 |
+
"resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.1.1.tgz",
|
| 179 |
+
"integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==",
|
| 180 |
+
"dev": true,
|
| 181 |
+
"license": "MIT",
|
| 182 |
+
"dependencies": {
|
| 183 |
+
"to-regex-range": "^5.0.1"
|
| 184 |
+
},
|
| 185 |
+
"engines": {
|
| 186 |
+
"node": ">=8"
|
| 187 |
+
}
|
| 188 |
+
},
|
| 189 |
+
"node_modules/find-cache-dir": {
|
| 190 |
+
"version": "3.3.2",
|
| 191 |
+
"resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-3.3.2.tgz",
|
| 192 |
+
"integrity": "sha512-wXZV5emFEjrridIgED11OoUKLxiYjAcqot/NJdAkOhlJ+vGzwhOAfcG5OX1jP+S0PcjEn8bdMJv+g2jwQ3Onig==",
|
| 193 |
+
"dev": true,
|
| 194 |
+
"license": "MIT",
|
| 195 |
+
"dependencies": {
|
| 196 |
+
"commondir": "^1.0.1",
|
| 197 |
+
"make-dir": "^3.0.2",
|
| 198 |
+
"pkg-dir": "^4.1.0"
|
| 199 |
+
},
|
| 200 |
+
"engines": {
|
| 201 |
+
"node": ">=8"
|
| 202 |
+
},
|
| 203 |
+
"funding": {
|
| 204 |
+
"url": "https://github.com/avajs/find-cache-dir?sponsor=1"
|
| 205 |
+
}
|
| 206 |
+
},
|
| 207 |
+
"node_modules/find-up": {
|
| 208 |
+
"version": "4.1.0",
|
| 209 |
+
"resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz",
|
| 210 |
+
"integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==",
|
| 211 |
+
"dev": true,
|
| 212 |
+
"license": "MIT",
|
| 213 |
+
"dependencies": {
|
| 214 |
+
"locate-path": "^5.0.0",
|
| 215 |
+
"path-exists": "^4.0.0"
|
| 216 |
+
},
|
| 217 |
+
"engines": {
|
| 218 |
+
"node": ">=8"
|
| 219 |
+
}
|
| 220 |
+
},
|
| 221 |
+
"node_modules/fs-extra": {
|
| 222 |
+
"version": "11.3.2",
|
| 223 |
+
"resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-11.3.2.tgz",
|
| 224 |
+
"integrity": "sha512-Xr9F6z6up6Ws+NjzMCZc6WXg2YFRlrLP9NQDO3VQrWrfiojdhS56TzueT88ze0uBdCTwEIhQ3ptnmKeWGFAe0A==",
|
| 225 |
+
"dev": true,
|
| 226 |
+
"license": "MIT",
|
| 227 |
+
"dependencies": {
|
| 228 |
+
"graceful-fs": "^4.2.0",
|
| 229 |
+
"jsonfile": "^6.0.1",
|
| 230 |
+
"universalify": "^2.0.0"
|
| 231 |
+
},
|
| 232 |
+
"engines": {
|
| 233 |
+
"node": ">=14.14"
|
| 234 |
+
}
|
| 235 |
+
},
|
| 236 |
+
"node_modules/gh-pages": {
|
| 237 |
+
"version": "6.3.0",
|
| 238 |
+
"resolved": "https://registry.npmjs.org/gh-pages/-/gh-pages-6.3.0.tgz",
|
| 239 |
+
"integrity": "sha512-Ot5lU6jK0Eb+sszG8pciXdjMXdBJ5wODvgjR+imihTqsUWF2K6dJ9HST55lgqcs8wWcw6o6wAsUzfcYRhJPXbA==",
|
| 240 |
+
"dev": true,
|
| 241 |
+
"license": "MIT",
|
| 242 |
+
"dependencies": {
|
| 243 |
+
"async": "^3.2.4",
|
| 244 |
+
"commander": "^13.0.0",
|
| 245 |
+
"email-addresses": "^5.0.0",
|
| 246 |
+
"filenamify": "^4.3.0",
|
| 247 |
+
"find-cache-dir": "^3.3.1",
|
| 248 |
+
"fs-extra": "^11.1.1",
|
| 249 |
+
"globby": "^11.1.0"
|
| 250 |
+
},
|
| 251 |
+
"bin": {
|
| 252 |
+
"gh-pages": "bin/gh-pages.js",
|
| 253 |
+
"gh-pages-clean": "bin/gh-pages-clean.js"
|
| 254 |
+
},
|
| 255 |
+
"engines": {
|
| 256 |
+
"node": ">=10"
|
| 257 |
+
}
|
| 258 |
+
},
|
| 259 |
+
"node_modules/glob-parent": {
|
| 260 |
+
"version": "5.1.2",
|
| 261 |
+
"resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz",
|
| 262 |
+
"integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==",
|
| 263 |
+
"dev": true,
|
| 264 |
+
"license": "ISC",
|
| 265 |
+
"dependencies": {
|
| 266 |
+
"is-glob": "^4.0.1"
|
| 267 |
+
},
|
| 268 |
+
"engines": {
|
| 269 |
+
"node": ">= 6"
|
| 270 |
+
}
|
| 271 |
+
},
|
| 272 |
+
"node_modules/globby": {
|
| 273 |
+
"version": "11.1.0",
|
| 274 |
+
"resolved": "https://registry.npmjs.org/globby/-/globby-11.1.0.tgz",
|
| 275 |
+
"integrity": "sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==",
|
| 276 |
+
"dev": true,
|
| 277 |
+
"license": "MIT",
|
| 278 |
+
"dependencies": {
|
| 279 |
+
"array-union": "^2.1.0",
|
| 280 |
+
"dir-glob": "^3.0.1",
|
| 281 |
+
"fast-glob": "^3.2.9",
|
| 282 |
+
"ignore": "^5.2.0",
|
| 283 |
+
"merge2": "^1.4.1",
|
| 284 |
+
"slash": "^3.0.0"
|
| 285 |
+
},
|
| 286 |
+
"engines": {
|
| 287 |
+
"node": ">=10"
|
| 288 |
+
},
|
| 289 |
+
"funding": {
|
| 290 |
+
"url": "https://github.com/sponsors/sindresorhus"
|
| 291 |
+
}
|
| 292 |
+
},
|
| 293 |
+
"node_modules/graceful-fs": {
|
| 294 |
+
"version": "4.2.11",
|
| 295 |
+
"resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz",
|
| 296 |
+
"integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==",
|
| 297 |
+
"dev": true,
|
| 298 |
+
"license": "ISC"
|
| 299 |
+
},
|
| 300 |
+
"node_modules/ignore": {
|
| 301 |
+
"version": "5.3.2",
|
| 302 |
+
"resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.2.tgz",
|
| 303 |
+
"integrity": "sha512-hsBTNUqQTDwkWtcdYI2i06Y/nUBEsNEDJKjWdigLvegy8kDuJAS8uRlpkkcQpyEXL0Z/pjDy5HBmMjRCJ2gq+g==",
|
| 304 |
+
"dev": true,
|
| 305 |
+
"license": "MIT",
|
| 306 |
+
"engines": {
|
| 307 |
+
"node": ">= 4"
|
| 308 |
+
}
|
| 309 |
+
},
|
| 310 |
+
"node_modules/is-extglob": {
|
| 311 |
+
"version": "2.1.1",
|
| 312 |
+
"resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
|
| 313 |
+
"integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==",
|
| 314 |
+
"dev": true,
|
| 315 |
+
"license": "MIT",
|
| 316 |
+
"engines": {
|
| 317 |
+
"node": ">=0.10.0"
|
| 318 |
+
}
|
| 319 |
+
},
|
| 320 |
+
"node_modules/is-glob": {
|
| 321 |
+
"version": "4.0.3",
|
| 322 |
+
"resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz",
|
| 323 |
+
"integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==",
|
| 324 |
+
"dev": true,
|
| 325 |
+
"license": "MIT",
|
| 326 |
+
"dependencies": {
|
| 327 |
+
"is-extglob": "^2.1.1"
|
| 328 |
+
},
|
| 329 |
+
"engines": {
|
| 330 |
+
"node": ">=0.10.0"
|
| 331 |
+
}
|
| 332 |
+
},
|
| 333 |
+
"node_modules/is-number": {
|
| 334 |
+
"version": "7.0.0",
|
| 335 |
+
"resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz",
|
| 336 |
+
"integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==",
|
| 337 |
+
"dev": true,
|
| 338 |
+
"license": "MIT",
|
| 339 |
+
"engines": {
|
| 340 |
+
"node": ">=0.12.0"
|
| 341 |
+
}
|
| 342 |
+
},
|
| 343 |
+
"node_modules/jsonfile": {
|
| 344 |
+
"version": "6.2.0",
|
| 345 |
+
"resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-6.2.0.tgz",
|
| 346 |
+
"integrity": "sha512-FGuPw30AdOIUTRMC2OMRtQV+jkVj2cfPqSeWXv1NEAJ1qZ5zb1X6z1mFhbfOB/iy3ssJCD+3KuZ8r8C3uVFlAg==",
|
| 347 |
+
"dev": true,
|
| 348 |
+
"license": "MIT",
|
| 349 |
+
"dependencies": {
|
| 350 |
+
"universalify": "^2.0.0"
|
| 351 |
+
},
|
| 352 |
+
"optionalDependencies": {
|
| 353 |
+
"graceful-fs": "^4.1.6"
|
| 354 |
+
}
|
| 355 |
+
},
|
| 356 |
+
"node_modules/locate-path": {
|
| 357 |
+
"version": "5.0.0",
|
| 358 |
+
"resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz",
|
| 359 |
+
"integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==",
|
| 360 |
+
"dev": true,
|
| 361 |
+
"license": "MIT",
|
| 362 |
+
"dependencies": {
|
| 363 |
+
"p-locate": "^4.1.0"
|
| 364 |
+
},
|
| 365 |
+
"engines": {
|
| 366 |
+
"node": ">=8"
|
| 367 |
+
}
|
| 368 |
+
},
|
| 369 |
+
"node_modules/make-dir": {
|
| 370 |
+
"version": "3.1.0",
|
| 371 |
+
"resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz",
|
| 372 |
+
"integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==",
|
| 373 |
+
"dev": true,
|
| 374 |
+
"license": "MIT",
|
| 375 |
+
"dependencies": {
|
| 376 |
+
"semver": "^6.0.0"
|
| 377 |
+
},
|
| 378 |
+
"engines": {
|
| 379 |
+
"node": ">=8"
|
| 380 |
+
},
|
| 381 |
+
"funding": {
|
| 382 |
+
"url": "https://github.com/sponsors/sindresorhus"
|
| 383 |
+
}
|
| 384 |
+
},
|
| 385 |
+
"node_modules/merge2": {
|
| 386 |
+
"version": "1.4.1",
|
| 387 |
+
"resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz",
|
| 388 |
+
"integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==",
|
| 389 |
+
"dev": true,
|
| 390 |
+
"license": "MIT",
|
| 391 |
+
"engines": {
|
| 392 |
+
"node": ">= 8"
|
| 393 |
+
}
|
| 394 |
+
},
|
| 395 |
+
"node_modules/micromatch": {
|
| 396 |
+
"version": "4.0.8",
|
| 397 |
+
"resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.8.tgz",
|
| 398 |
+
"integrity": "sha512-PXwfBhYu0hBCPw8Dn0E+WDYb7af3dSLVWKi3HGv84IdF4TyFoC0ysxFd0Goxw7nSv4T/PzEJQxsYsEiFCKo2BA==",
|
| 399 |
+
"dev": true,
|
| 400 |
+
"license": "MIT",
|
| 401 |
+
"dependencies": {
|
| 402 |
+
"braces": "^3.0.3",
|
| 403 |
+
"picomatch": "^2.3.1"
|
| 404 |
+
},
|
| 405 |
+
"engines": {
|
| 406 |
+
"node": ">=8.6"
|
| 407 |
+
}
|
| 408 |
+
},
|
| 409 |
+
"node_modules/p-limit": {
|
| 410 |
+
"version": "2.3.0",
|
| 411 |
+
"resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz",
|
| 412 |
+
"integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==",
|
| 413 |
+
"dev": true,
|
| 414 |
+
"license": "MIT",
|
| 415 |
+
"dependencies": {
|
| 416 |
+
"p-try": "^2.0.0"
|
| 417 |
+
},
|
| 418 |
+
"engines": {
|
| 419 |
+
"node": ">=6"
|
| 420 |
+
},
|
| 421 |
+
"funding": {
|
| 422 |
+
"url": "https://github.com/sponsors/sindresorhus"
|
| 423 |
+
}
|
| 424 |
+
},
|
| 425 |
+
"node_modules/p-locate": {
|
| 426 |
+
"version": "4.1.0",
|
| 427 |
+
"resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz",
|
| 428 |
+
"integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==",
|
| 429 |
+
"dev": true,
|
| 430 |
+
"license": "MIT",
|
| 431 |
+
"dependencies": {
|
| 432 |
+
"p-limit": "^2.2.0"
|
| 433 |
+
},
|
| 434 |
+
"engines": {
|
| 435 |
+
"node": ">=8"
|
| 436 |
+
}
|
| 437 |
+
},
|
| 438 |
+
"node_modules/p-try": {
|
| 439 |
+
"version": "2.2.0",
|
| 440 |
+
"resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz",
|
| 441 |
+
"integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==",
|
| 442 |
+
"dev": true,
|
| 443 |
+
"license": "MIT",
|
| 444 |
+
"engines": {
|
| 445 |
+
"node": ">=6"
|
| 446 |
+
}
|
| 447 |
+
},
|
| 448 |
+
"node_modules/path-exists": {
|
| 449 |
+
"version": "4.0.0",
|
| 450 |
+
"resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz",
|
| 451 |
+
"integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==",
|
| 452 |
+
"dev": true,
|
| 453 |
+
"license": "MIT",
|
| 454 |
+
"engines": {
|
| 455 |
+
"node": ">=8"
|
| 456 |
+
}
|
| 457 |
+
},
|
| 458 |
+
"node_modules/path-type": {
|
| 459 |
+
"version": "4.0.0",
|
| 460 |
+
"resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz",
|
| 461 |
+
"integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==",
|
| 462 |
+
"dev": true,
|
| 463 |
+
"license": "MIT",
|
| 464 |
+
"engines": {
|
| 465 |
+
"node": ">=8"
|
| 466 |
+
}
|
| 467 |
+
},
|
| 468 |
+
"node_modules/picomatch": {
|
| 469 |
+
"version": "2.3.1",
|
| 470 |
+
"resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz",
|
| 471 |
+
"integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==",
|
| 472 |
+
"dev": true,
|
| 473 |
+
"license": "MIT",
|
| 474 |
+
"engines": {
|
| 475 |
+
"node": ">=8.6"
|
| 476 |
+
},
|
| 477 |
+
"funding": {
|
| 478 |
+
"url": "https://github.com/sponsors/jonschlinkert"
|
| 479 |
+
}
|
| 480 |
+
},
|
| 481 |
+
"node_modules/pkg-dir": {
|
| 482 |
+
"version": "4.2.0",
|
| 483 |
+
"resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz",
|
| 484 |
+
"integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==",
|
| 485 |
+
"dev": true,
|
| 486 |
+
"license": "MIT",
|
| 487 |
+
"dependencies": {
|
| 488 |
+
"find-up": "^4.0.0"
|
| 489 |
+
},
|
| 490 |
+
"engines": {
|
| 491 |
+
"node": ">=8"
|
| 492 |
+
}
|
| 493 |
+
},
|
| 494 |
+
"node_modules/queue-microtask": {
|
| 495 |
+
"version": "1.2.3",
|
| 496 |
+
"resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz",
|
| 497 |
+
"integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==",
|
| 498 |
+
"dev": true,
|
| 499 |
+
"funding": [
|
| 500 |
+
{
|
| 501 |
+
"type": "github",
|
| 502 |
+
"url": "https://github.com/sponsors/feross"
|
| 503 |
+
},
|
| 504 |
+
{
|
| 505 |
+
"type": "patreon",
|
| 506 |
+
"url": "https://www.patreon.com/feross"
|
| 507 |
+
},
|
| 508 |
+
{
|
| 509 |
+
"type": "consulting",
|
| 510 |
+
"url": "https://feross.org/support"
|
| 511 |
+
}
|
| 512 |
+
],
|
| 513 |
+
"license": "MIT"
|
| 514 |
+
},
|
| 515 |
+
"node_modules/reusify": {
|
| 516 |
+
"version": "1.1.0",
|
| 517 |
+
"resolved": "https://registry.npmjs.org/reusify/-/reusify-1.1.0.tgz",
|
| 518 |
+
"integrity": "sha512-g6QUff04oZpHs0eG5p83rFLhHeV00ug/Yf9nZM6fLeUrPguBTkTQOdpAWWspMh55TZfVQDPaN3NQJfbVRAxdIw==",
|
| 519 |
+
"dev": true,
|
| 520 |
+
"license": "MIT",
|
| 521 |
+
"engines": {
|
| 522 |
+
"iojs": ">=1.0.0",
|
| 523 |
+
"node": ">=0.10.0"
|
| 524 |
+
}
|
| 525 |
+
},
|
| 526 |
+
"node_modules/run-parallel": {
|
| 527 |
+
"version": "1.2.0",
|
| 528 |
+
"resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz",
|
| 529 |
+
"integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==",
|
| 530 |
+
"dev": true,
|
| 531 |
+
"funding": [
|
| 532 |
+
{
|
| 533 |
+
"type": "github",
|
| 534 |
+
"url": "https://github.com/sponsors/feross"
|
| 535 |
+
},
|
| 536 |
+
{
|
| 537 |
+
"type": "patreon",
|
| 538 |
+
"url": "https://www.patreon.com/feross"
|
| 539 |
+
},
|
| 540 |
+
{
|
| 541 |
+
"type": "consulting",
|
| 542 |
+
"url": "https://feross.org/support"
|
| 543 |
+
}
|
| 544 |
+
],
|
| 545 |
+
"license": "MIT",
|
| 546 |
+
"dependencies": {
|
| 547 |
+
"queue-microtask": "^1.2.2"
|
| 548 |
+
}
|
| 549 |
+
},
|
| 550 |
+
"node_modules/semver": {
|
| 551 |
+
"version": "6.3.1",
|
| 552 |
+
"resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz",
|
| 553 |
+
"integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==",
|
| 554 |
+
"dev": true,
|
| 555 |
+
"license": "ISC",
|
| 556 |
+
"bin": {
|
| 557 |
+
"semver": "bin/semver.js"
|
| 558 |
+
}
|
| 559 |
+
},
|
| 560 |
+
"node_modules/slash": {
|
| 561 |
+
"version": "3.0.0",
|
| 562 |
+
"resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz",
|
| 563 |
+
"integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==",
|
| 564 |
+
"dev": true,
|
| 565 |
+
"license": "MIT",
|
| 566 |
+
"engines": {
|
| 567 |
+
"node": ">=8"
|
| 568 |
+
}
|
| 569 |
+
},
|
| 570 |
+
"node_modules/strip-outer": {
|
| 571 |
+
"version": "1.0.1",
|
| 572 |
+
"resolved": "https://registry.npmjs.org/strip-outer/-/strip-outer-1.0.1.tgz",
|
| 573 |
+
"integrity": "sha512-k55yxKHwaXnpYGsOzg4Vl8+tDrWylxDEpknGjhTiZB8dFRU5rTo9CAzeycivxV3s+zlTKwrs6WxMxR95n26kwg==",
|
| 574 |
+
"dev": true,
|
| 575 |
+
"license": "MIT",
|
| 576 |
+
"dependencies": {
|
| 577 |
+
"escape-string-regexp": "^1.0.2"
|
| 578 |
+
},
|
| 579 |
+
"engines": {
|
| 580 |
+
"node": ">=0.10.0"
|
| 581 |
+
}
|
| 582 |
+
},
|
| 583 |
+
"node_modules/to-regex-range": {
|
| 584 |
+
"version": "5.0.1",
|
| 585 |
+
"resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz",
|
| 586 |
+
"integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==",
|
| 587 |
+
"dev": true,
|
| 588 |
+
"license": "MIT",
|
| 589 |
+
"dependencies": {
|
| 590 |
+
"is-number": "^7.0.0"
|
| 591 |
+
},
|
| 592 |
+
"engines": {
|
| 593 |
+
"node": ">=8.0"
|
| 594 |
+
}
|
| 595 |
+
},
|
| 596 |
+
"node_modules/trim-repeated": {
|
| 597 |
+
"version": "1.0.0",
|
| 598 |
+
"resolved": "https://registry.npmjs.org/trim-repeated/-/trim-repeated-1.0.0.tgz",
|
| 599 |
+
"integrity": "sha512-pkonvlKk8/ZuR0D5tLW8ljt5I8kmxp2XKymhepUeOdCEfKpZaktSArkLHZt76OB1ZvO9bssUsDty4SWhLvZpLg==",
|
| 600 |
+
"dev": true,
|
| 601 |
+
"license": "MIT",
|
| 602 |
+
"dependencies": {
|
| 603 |
+
"escape-string-regexp": "^1.0.2"
|
| 604 |
+
},
|
| 605 |
+
"engines": {
|
| 606 |
+
"node": ">=0.10.0"
|
| 607 |
+
}
|
| 608 |
+
},
|
| 609 |
+
"node_modules/universalify": {
|
| 610 |
+
"version": "2.0.1",
|
| 611 |
+
"resolved": "https://registry.npmjs.org/universalify/-/universalify-2.0.1.tgz",
|
| 612 |
+
"integrity": "sha512-gptHNQghINnc/vTGIk0SOFGFNXw7JVrlRUtConJRlvaw6DuX0wO5Jeko9sWrMBhh+PsYAZ7oXAiOnf/UKogyiw==",
|
| 613 |
+
"dev": true,
|
| 614 |
+
"license": "MIT",
|
| 615 |
+
"engines": {
|
| 616 |
+
"node": ">= 10.0.0"
|
| 617 |
+
}
|
| 618 |
+
}
|
| 619 |
+
}
|
| 620 |
+
}
|
node_modules/@nodelib/fs.scandir/LICENSE
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
The MIT License (MIT)
|
| 2 |
+
|
| 3 |
+
Copyright (c) Denis Malinochkin
|
| 4 |
+
|
| 5 |
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
| 6 |
+
of this software and associated documentation files (the "Software"), to deal
|
| 7 |
+
in the Software without restriction, including without limitation the rights
|
| 8 |
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
| 9 |
+
copies of the Software, and to permit persons to whom the Software is
|
| 10 |
+
furnished to do so, subject to the following conditions:
|
| 11 |
+
|
| 12 |
+
The above copyright notice and this permission notice shall be included in all
|
| 13 |
+
copies or substantial portions of the Software.
|
| 14 |
+
|
| 15 |
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
| 16 |
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
| 17 |
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
| 18 |
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
| 19 |
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
| 20 |
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
| 21 |
+
SOFTWARE.
|
node_modules/@nodelib/fs.scandir/README.md
ADDED
|
@@ -0,0 +1,171 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
# @nodelib/fs.scandir
|
| 2 |
+
|
| 3 |
+
> List files and directories inside the specified directory.
|
| 4 |
+
|
| 5 |
+
## :bulb: Highlights
|
| 6 |
+
|
| 7 |
+
The package is aimed at obtaining information about entries in the directory.
|
| 8 |
+
|
| 9 |
+
* :moneybag: Returns useful information: `name`, `path`, `dirent` and `stats` (optional).
|
| 10 |
+
* :gear: On Node.js 10.10+ uses the mechanism without additional calls to determine the entry type. See [`old` and `modern` mode](#old-and-modern-mode).
|
| 11 |
+
* :link: Can safely work with broken symbolic links.
|
| 12 |
+
|
| 13 |
+
## Install
|
| 14 |
+
|
| 15 |
+
```console
|
| 16 |
+
npm install @nodelib/fs.scandir
|
| 17 |
+
```
|
| 18 |
+
|
| 19 |
+
## Usage
|
| 20 |
+
|
| 21 |
+
```ts
|
| 22 |
+
import * as fsScandir from '@nodelib/fs.scandir';
|
| 23 |
+
|
| 24 |
+
fsScandir.scandir('path', (error, stats) => { /* … */ });
|
| 25 |
+
```
|
| 26 |
+
|
| 27 |
+
## API
|
| 28 |
+
|
| 29 |
+
### .scandir(path, [optionsOrSettings], callback)
|
| 30 |
+
|
| 31 |
+
Returns an array of plain objects ([`Entry`](#entry)) with information about entry for provided path with standard callback-style.
|
| 32 |
+
|
| 33 |
+
```ts
|
| 34 |
+
fsScandir.scandir('path', (error, entries) => { /* … */ });
|
| 35 |
+
fsScandir.scandir('path', {}, (error, entries) => { /* … */ });
|
| 36 |
+
fsScandir.scandir('path', new fsScandir.Settings(), (error, entries) => { /* … */ });
|
| 37 |
+
```
|
| 38 |
+
|
| 39 |
+
### .scandirSync(path, [optionsOrSettings])
|
| 40 |
+
|
| 41 |
+
Returns an array of plain objects ([`Entry`](#entry)) with information about entry for provided path.
|
| 42 |
+
|
| 43 |
+
```ts
|
| 44 |
+
const entries = fsScandir.scandirSync('path');
|
| 45 |
+
const entries = fsScandir.scandirSync('path', {});
|
| 46 |
+
const entries = fsScandir.scandirSync(('path', new fsScandir.Settings());
|
| 47 |
+
```
|
| 48 |
+
|
| 49 |
+
#### path
|
| 50 |
+
|
| 51 |
+
* Required: `true`
|
| 52 |
+
* Type: `string | Buffer | URL`
|
| 53 |
+
|
| 54 |
+
A path to a file. If a URL is provided, it must use the `file:` protocol.
|
| 55 |
+
|
| 56 |
+
#### optionsOrSettings
|
| 57 |
+
|
| 58 |
+
* Required: `false`
|
| 59 |
+
* Type: `Options | Settings`
|
| 60 |
+
* Default: An instance of `Settings` class
|
| 61 |
+
|
| 62 |
+
An [`Options`](#options) object or an instance of [`Settings`](#settingsoptions) class.
|
| 63 |
+
|
| 64 |
+
> :book: When you pass a plain object, an instance of the `Settings` class will be created automatically. If you plan to call the method frequently, use a pre-created instance of the `Settings` class.
|
| 65 |
+
|
| 66 |
+
### Settings([options])
|
| 67 |
+
|
| 68 |
+
A class of full settings of the package.
|
| 69 |
+
|
| 70 |
+
```ts
|
| 71 |
+
const settings = new fsScandir.Settings({ followSymbolicLinks: false });
|
| 72 |
+
|
| 73 |
+
const entries = fsScandir.scandirSync('path', settings);
|
| 74 |
+
```
|
| 75 |
+
|
| 76 |
+
## Entry
|
| 77 |
+
|
| 78 |
+
* `name` — The name of the entry (`unknown.txt`).
|
| 79 |
+
* `path` — The path of the entry relative to call directory (`root/unknown.txt`).
|
| 80 |
+
* `dirent` — An instance of [`fs.Dirent`](./src/types/index.ts) class. On Node.js below 10.10 will be emulated by [`DirentFromStats`](./src/utils/fs.ts) class.
|
| 81 |
+
* `stats` (optional) — An instance of `fs.Stats` class.
|
| 82 |
+
|
| 83 |
+
For example, the `scandir` call for `tools` directory with one directory inside:
|
| 84 |
+
|
| 85 |
+
```ts
|
| 86 |
+
{
|
| 87 |
+
dirent: Dirent { name: 'typedoc', /* … */ },
|
| 88 |
+
name: 'typedoc',
|
| 89 |
+
path: 'tools/typedoc'
|
| 90 |
+
}
|
| 91 |
+
```
|
| 92 |
+
|
| 93 |
+
## Options
|
| 94 |
+
|
| 95 |
+
### stats
|
| 96 |
+
|
| 97 |
+
* Type: `boolean`
|
| 98 |
+
* Default: `false`
|
| 99 |
+
|
| 100 |
+
Adds an instance of `fs.Stats` class to the [`Entry`](#entry).
|
| 101 |
+
|
| 102 |
+
> :book: Always use `fs.readdir` without the `withFileTypes` option. ??TODO??
|
| 103 |
+
|
| 104 |
+
### followSymbolicLinks
|
| 105 |
+
|
| 106 |
+
* Type: `boolean`
|
| 107 |
+
* Default: `false`
|
| 108 |
+
|
| 109 |
+
Follow symbolic links or not. Call `fs.stat` on symbolic link if `true`.
|
| 110 |
+
|
| 111 |
+
### `throwErrorOnBrokenSymbolicLink`
|
| 112 |
+
|
| 113 |
+
* Type: `boolean`
|
| 114 |
+
* Default: `true`
|
| 115 |
+
|
| 116 |
+
Throw an error when symbolic link is broken if `true` or safely use `lstat` call if `false`.
|
| 117 |
+
|
| 118 |
+
### `pathSegmentSeparator`
|
| 119 |
+
|
| 120 |
+
* Type: `string`
|
| 121 |
+
* Default: `path.sep`
|
| 122 |
+
|
| 123 |
+
By default, this package uses the correct path separator for your OS (`\` on Windows, `/` on Unix-like systems). But you can set this option to any separator character(s) that you want to use instead.
|
| 124 |
+
|
| 125 |
+
### `fs`
|
| 126 |
+
|
| 127 |
+
* Type: [`FileSystemAdapter`](./src/adapters/fs.ts)
|
| 128 |
+
* Default: A default FS methods
|
| 129 |
+
|
| 130 |
+
By default, the built-in Node.js module (`fs`) is used to work with the file system. You can replace any method with your own.
|
| 131 |
+
|
| 132 |
+
```ts
|
| 133 |
+
interface FileSystemAdapter {
|
| 134 |
+
lstat?: typeof fs.lstat;
|
| 135 |
+
stat?: typeof fs.stat;
|
| 136 |
+
lstatSync?: typeof fs.lstatSync;
|
| 137 |
+
statSync?: typeof fs.statSync;
|
| 138 |
+
readdir?: typeof fs.readdir;
|
| 139 |
+
readdirSync?: typeof fs.readdirSync;
|
| 140 |
+
}
|
| 141 |
+
|
| 142 |
+
const settings = new fsScandir.Settings({
|
| 143 |
+
fs: { lstat: fakeLstat }
|
| 144 |
+
});
|
| 145 |
+
```
|
| 146 |
+
|
| 147 |
+
## `old` and `modern` mode
|
| 148 |
+
|
| 149 |
+
This package has two modes that are used depending on the environment and parameters of use.
|
| 150 |
+
|
| 151 |
+
### old
|
| 152 |
+
|
| 153 |
+
* Node.js below `10.10` or when the `stats` option is enabled
|
| 154 |
+
|
| 155 |
+
When working in the old mode, the directory is read first (`fs.readdir`), then the type of entries is determined (`fs.lstat` and/or `fs.stat` for symbolic links).
|
| 156 |
+
|
| 157 |
+
### modern
|
| 158 |
+
|
| 159 |
+
* Node.js 10.10+ and the `stats` option is disabled
|
| 160 |
+
|
| 161 |
+
In the modern mode, reading the directory (`fs.readdir` with the `withFileTypes` option) is combined with obtaining information about its entries. An additional call for symbolic links (`fs.stat`) is still present.
|
| 162 |
+
|
| 163 |
+
This mode makes fewer calls to the file system. It's faster.
|
| 164 |
+
|
| 165 |
+
## Changelog
|
| 166 |
+
|
| 167 |
+
See the [Releases section of our GitHub project](https://github.com/nodelib/nodelib/releases) for changelog for each release version.
|
| 168 |
+
|
| 169 |
+
## License
|
| 170 |
+
|
| 171 |
+
This software is released under the terms of the MIT license.
|
node_modules/@nodelib/fs.scandir/out/adapters/fs.d.ts
ADDED
|
@@ -0,0 +1,20 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
import type * as fsStat from '@nodelib/fs.stat';
|
| 2 |
+
import type { Dirent, ErrnoException } from '../types';
|
| 3 |
+
export interface ReaddirAsynchronousMethod {
|
| 4 |
+
(filepath: string, options: {
|
| 5 |
+
withFileTypes: true;
|
| 6 |
+
}, callback: (error: ErrnoException | null, files: Dirent[]) => void): void;
|
| 7 |
+
(filepath: string, callback: (error: ErrnoException | null, files: string[]) => void): void;
|
| 8 |
+
}
|
| 9 |
+
export interface ReaddirSynchronousMethod {
|
| 10 |
+
(filepath: string, options: {
|
| 11 |
+
withFileTypes: true;
|
| 12 |
+
}): Dirent[];
|
| 13 |
+
(filepath: string): string[];
|
| 14 |
+
}
|
| 15 |
+
export declare type FileSystemAdapter = fsStat.FileSystemAdapter & {
|
| 16 |
+
readdir: ReaddirAsynchronousMethod;
|
| 17 |
+
readdirSync: ReaddirSynchronousMethod;
|
| 18 |
+
};
|
| 19 |
+
export declare const FILE_SYSTEM_ADAPTER: FileSystemAdapter;
|
| 20 |
+
export declare function createFileSystemAdapter(fsMethods?: Partial<FileSystemAdapter>): FileSystemAdapter;
|
node_modules/@nodelib/fs.scandir/out/adapters/fs.js
ADDED
|
@@ -0,0 +1,19 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
"use strict";
|
| 2 |
+
Object.defineProperty(exports, "__esModule", { value: true });
|
| 3 |
+
exports.createFileSystemAdapter = exports.FILE_SYSTEM_ADAPTER = void 0;
|
| 4 |
+
const fs = require("fs");
|
| 5 |
+
exports.FILE_SYSTEM_ADAPTER = {
|
| 6 |
+
lstat: fs.lstat,
|
| 7 |
+
stat: fs.stat,
|
| 8 |
+
lstatSync: fs.lstatSync,
|
| 9 |
+
statSync: fs.statSync,
|
| 10 |
+
readdir: fs.readdir,
|
| 11 |
+
readdirSync: fs.readdirSync
|
| 12 |
+
};
|
| 13 |
+
function createFileSystemAdapter(fsMethods) {
|
| 14 |
+
if (fsMethods === undefined) {
|
| 15 |
+
return exports.FILE_SYSTEM_ADAPTER;
|
| 16 |
+
}
|
| 17 |
+
return Object.assign(Object.assign({}, exports.FILE_SYSTEM_ADAPTER), fsMethods);
|
| 18 |
+
}
|
| 19 |
+
exports.createFileSystemAdapter = createFileSystemAdapter;
|
node_modules/@nodelib/fs.scandir/out/constants.d.ts
ADDED
|
@@ -0,0 +1,4 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
/**
|
| 2 |
+
* IS `true` for Node.js 10.10 and greater.
|
| 3 |
+
*/
|
| 4 |
+
export declare const IS_SUPPORT_READDIR_WITH_FILE_TYPES: boolean;
|
node_modules/@nodelib/fs.scandir/out/constants.js
ADDED
|
@@ -0,0 +1,17 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
"use strict";
|
| 2 |
+
Object.defineProperty(exports, "__esModule", { value: true });
|
| 3 |
+
exports.IS_SUPPORT_READDIR_WITH_FILE_TYPES = void 0;
|
| 4 |
+
const NODE_PROCESS_VERSION_PARTS = process.versions.node.split('.');
|
| 5 |
+
if (NODE_PROCESS_VERSION_PARTS[0] === undefined || NODE_PROCESS_VERSION_PARTS[1] === undefined) {
|
| 6 |
+
throw new Error(`Unexpected behavior. The 'process.versions.node' variable has invalid value: ${process.versions.node}`);
|
| 7 |
+
}
|
| 8 |
+
const MAJOR_VERSION = Number.parseInt(NODE_PROCESS_VERSION_PARTS[0], 10);
|
| 9 |
+
const MINOR_VERSION = Number.parseInt(NODE_PROCESS_VERSION_PARTS[1], 10);
|
| 10 |
+
const SUPPORTED_MAJOR_VERSION = 10;
|
| 11 |
+
const SUPPORTED_MINOR_VERSION = 10;
|
| 12 |
+
const IS_MATCHED_BY_MAJOR = MAJOR_VERSION > SUPPORTED_MAJOR_VERSION;
|
| 13 |
+
const IS_MATCHED_BY_MAJOR_AND_MINOR = MAJOR_VERSION === SUPPORTED_MAJOR_VERSION && MINOR_VERSION >= SUPPORTED_MINOR_VERSION;
|
| 14 |
+
/**
|
| 15 |
+
* IS `true` for Node.js 10.10 and greater.
|
| 16 |
+
*/
|
| 17 |
+
exports.IS_SUPPORT_READDIR_WITH_FILE_TYPES = IS_MATCHED_BY_MAJOR || IS_MATCHED_BY_MAJOR_AND_MINOR;
|
node_modules/@nodelib/fs.scandir/out/index.d.ts
ADDED
|
@@ -0,0 +1,12 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
import type { FileSystemAdapter, ReaddirAsynchronousMethod, ReaddirSynchronousMethod } from './adapters/fs';
|
| 2 |
+
import * as async from './providers/async';
|
| 3 |
+
import Settings, { Options } from './settings';
|
| 4 |
+
import type { Dirent, Entry } from './types';
|
| 5 |
+
declare type AsyncCallback = async.AsyncCallback;
|
| 6 |
+
declare function scandir(path: string, callback: AsyncCallback): void;
|
| 7 |
+
declare function scandir(path: string, optionsOrSettings: Options | Settings, callback: AsyncCallback): void;
|
| 8 |
+
declare namespace scandir {
|
| 9 |
+
function __promisify__(path: string, optionsOrSettings?: Options | Settings): Promise<Entry[]>;
|
| 10 |
+
}
|
| 11 |
+
declare function scandirSync(path: string, optionsOrSettings?: Options | Settings): Entry[];
|
| 12 |
+
export { scandir, scandirSync, Settings, AsyncCallback, Dirent, Entry, FileSystemAdapter, ReaddirAsynchronousMethod, ReaddirSynchronousMethod, Options };
|
node_modules/@nodelib/fs.scandir/out/index.js
ADDED
|
@@ -0,0 +1,26 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
"use strict";
|
| 2 |
+
Object.defineProperty(exports, "__esModule", { value: true });
|
| 3 |
+
exports.Settings = exports.scandirSync = exports.scandir = void 0;
|
| 4 |
+
const async = require("./providers/async");
|
| 5 |
+
const sync = require("./providers/sync");
|
| 6 |
+
const settings_1 = require("./settings");
|
| 7 |
+
exports.Settings = settings_1.default;
|
| 8 |
+
function scandir(path, optionsOrSettingsOrCallback, callback) {
|
| 9 |
+
if (typeof optionsOrSettingsOrCallback === 'function') {
|
| 10 |
+
async.read(path, getSettings(), optionsOrSettingsOrCallback);
|
| 11 |
+
return;
|
| 12 |
+
}
|
| 13 |
+
async.read(path, getSettings(optionsOrSettingsOrCallback), callback);
|
| 14 |
+
}
|
| 15 |
+
exports.scandir = scandir;
|
| 16 |
+
function scandirSync(path, optionsOrSettings) {
|
| 17 |
+
const settings = getSettings(optionsOrSettings);
|
| 18 |
+
return sync.read(path, settings);
|
| 19 |
+
}
|
| 20 |
+
exports.scandirSync = scandirSync;
|
| 21 |
+
function getSettings(settingsOrOptions = {}) {
|
| 22 |
+
if (settingsOrOptions instanceof settings_1.default) {
|
| 23 |
+
return settingsOrOptions;
|
| 24 |
+
}
|
| 25 |
+
return new settings_1.default(settingsOrOptions);
|
| 26 |
+
}
|
node_modules/@nodelib/fs.scandir/out/providers/async.d.ts
ADDED
|
@@ -0,0 +1,7 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
/// <reference types="node" />
|
| 2 |
+
import type Settings from '../settings';
|
| 3 |
+
import type { Entry } from '../types';
|
| 4 |
+
export declare type AsyncCallback = (error: NodeJS.ErrnoException, entries: Entry[]) => void;
|
| 5 |
+
export declare function read(directory: string, settings: Settings, callback: AsyncCallback): void;
|
| 6 |
+
export declare function readdirWithFileTypes(directory: string, settings: Settings, callback: AsyncCallback): void;
|
| 7 |
+
export declare function readdir(directory: string, settings: Settings, callback: AsyncCallback): void;
|
node_modules/@nodelib/fs.scandir/out/providers/async.js
ADDED
|
@@ -0,0 +1,104 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
"use strict";
|
| 2 |
+
Object.defineProperty(exports, "__esModule", { value: true });
|
| 3 |
+
exports.readdir = exports.readdirWithFileTypes = exports.read = void 0;
|
| 4 |
+
const fsStat = require("@nodelib/fs.stat");
|
| 5 |
+
const rpl = require("run-parallel");
|
| 6 |
+
const constants_1 = require("../constants");
|
| 7 |
+
const utils = require("../utils");
|
| 8 |
+
const common = require("./common");
|
| 9 |
+
function read(directory, settings, callback) {
|
| 10 |
+
if (!settings.stats && constants_1.IS_SUPPORT_READDIR_WITH_FILE_TYPES) {
|
| 11 |
+
readdirWithFileTypes(directory, settings, callback);
|
| 12 |
+
return;
|
| 13 |
+
}
|
| 14 |
+
readdir(directory, settings, callback);
|
| 15 |
+
}
|
| 16 |
+
exports.read = read;
|
| 17 |
+
function readdirWithFileTypes(directory, settings, callback) {
|
| 18 |
+
settings.fs.readdir(directory, { withFileTypes: true }, (readdirError, dirents) => {
|
| 19 |
+
if (readdirError !== null) {
|
| 20 |
+
callFailureCallback(callback, readdirError);
|
| 21 |
+
return;
|
| 22 |
+
}
|
| 23 |
+
const entries = dirents.map((dirent) => ({
|
| 24 |
+
dirent,
|
| 25 |
+
name: dirent.name,
|
| 26 |
+
path: common.joinPathSegments(directory, dirent.name, settings.pathSegmentSeparator)
|
| 27 |
+
}));
|
| 28 |
+
if (!settings.followSymbolicLinks) {
|
| 29 |
+
callSuccessCallback(callback, entries);
|
| 30 |
+
return;
|
| 31 |
+
}
|
| 32 |
+
const tasks = entries.map((entry) => makeRplTaskEntry(entry, settings));
|
| 33 |
+
rpl(tasks, (rplError, rplEntries) => {
|
| 34 |
+
if (rplError !== null) {
|
| 35 |
+
callFailureCallback(callback, rplError);
|
| 36 |
+
return;
|
| 37 |
+
}
|
| 38 |
+
callSuccessCallback(callback, rplEntries);
|
| 39 |
+
});
|
| 40 |
+
});
|
| 41 |
+
}
|
| 42 |
+
exports.readdirWithFileTypes = readdirWithFileTypes;
|
| 43 |
+
function makeRplTaskEntry(entry, settings) {
|
| 44 |
+
return (done) => {
|
| 45 |
+
if (!entry.dirent.isSymbolicLink()) {
|
| 46 |
+
done(null, entry);
|
| 47 |
+
return;
|
| 48 |
+
}
|
| 49 |
+
settings.fs.stat(entry.path, (statError, stats) => {
|
| 50 |
+
if (statError !== null) {
|
| 51 |
+
if (settings.throwErrorOnBrokenSymbolicLink) {
|
| 52 |
+
done(statError);
|
| 53 |
+
return;
|
| 54 |
+
}
|
| 55 |
+
done(null, entry);
|
| 56 |
+
return;
|
| 57 |
+
}
|
| 58 |
+
entry.dirent = utils.fs.createDirentFromStats(entry.name, stats);
|
| 59 |
+
done(null, entry);
|
| 60 |
+
});
|
| 61 |
+
};
|
| 62 |
+
}
|
| 63 |
+
function readdir(directory, settings, callback) {
|
| 64 |
+
settings.fs.readdir(directory, (readdirError, names) => {
|
| 65 |
+
if (readdirError !== null) {
|
| 66 |
+
callFailureCallback(callback, readdirError);
|
| 67 |
+
return;
|
| 68 |
+
}
|
| 69 |
+
const tasks = names.map((name) => {
|
| 70 |
+
const path = common.joinPathSegments(directory, name, settings.pathSegmentSeparator);
|
| 71 |
+
return (done) => {
|
| 72 |
+
fsStat.stat(path, settings.fsStatSettings, (error, stats) => {
|
| 73 |
+
if (error !== null) {
|
| 74 |
+
done(error);
|
| 75 |
+
return;
|
| 76 |
+
}
|
| 77 |
+
const entry = {
|
| 78 |
+
name,
|
| 79 |
+
path,
|
| 80 |
+
dirent: utils.fs.createDirentFromStats(name, stats)
|
| 81 |
+
};
|
| 82 |
+
if (settings.stats) {
|
| 83 |
+
entry.stats = stats;
|
| 84 |
+
}
|
| 85 |
+
done(null, entry);
|
| 86 |
+
});
|
| 87 |
+
};
|
| 88 |
+
});
|
| 89 |
+
rpl(tasks, (rplError, entries) => {
|
| 90 |
+
if (rplError !== null) {
|
| 91 |
+
callFailureCallback(callback, rplError);
|
| 92 |
+
return;
|
| 93 |
+
}
|
| 94 |
+
callSuccessCallback(callback, entries);
|
| 95 |
+
});
|
| 96 |
+
});
|
| 97 |
+
}
|
| 98 |
+
exports.readdir = readdir;
|
| 99 |
+
function callFailureCallback(callback, error) {
|
| 100 |
+
callback(error);
|
| 101 |
+
}
|
| 102 |
+
function callSuccessCallback(callback, result) {
|
| 103 |
+
callback(null, result);
|
| 104 |
+
}
|
node_modules/@nodelib/fs.scandir/out/providers/common.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
|
|
|
|
| 1 |
+
export declare function joinPathSegments(a: string, b: string, separator: string): string;
|
node_modules/@nodelib/fs.scandir/out/providers/common.js
ADDED
|
@@ -0,0 +1,13 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
"use strict";
|
| 2 |
+
Object.defineProperty(exports, "__esModule", { value: true });
|
| 3 |
+
exports.joinPathSegments = void 0;
|
| 4 |
+
function joinPathSegments(a, b, separator) {
|
| 5 |
+
/**
|
| 6 |
+
* The correct handling of cases when the first segment is a root (`/`, `C:/`) or UNC path (`//?/C:/`).
|
| 7 |
+
*/
|
| 8 |
+
if (a.endsWith(separator)) {
|
| 9 |
+
return a + b;
|
| 10 |
+
}
|
| 11 |
+
return a + separator + b;
|
| 12 |
+
}
|
| 13 |
+
exports.joinPathSegments = joinPathSegments;
|
node_modules/@nodelib/fs.scandir/out/providers/sync.d.ts
ADDED
|
@@ -0,0 +1,5 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
import type Settings from '../settings';
|
| 2 |
+
import type { Entry } from '../types';
|
| 3 |
+
export declare function read(directory: string, settings: Settings): Entry[];
|
| 4 |
+
export declare function readdirWithFileTypes(directory: string, settings: Settings): Entry[];
|
| 5 |
+
export declare function readdir(directory: string, settings: Settings): Entry[];
|
node_modules/@nodelib/fs.scandir/out/providers/sync.js
ADDED
|
@@ -0,0 +1,54 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
"use strict";
|
| 2 |
+
Object.defineProperty(exports, "__esModule", { value: true });
|
| 3 |
+
exports.readdir = exports.readdirWithFileTypes = exports.read = void 0;
|
| 4 |
+
const fsStat = require("@nodelib/fs.stat");
|
| 5 |
+
const constants_1 = require("../constants");
|
| 6 |
+
const utils = require("../utils");
|
| 7 |
+
const common = require("./common");
|
| 8 |
+
function read(directory, settings) {
|
| 9 |
+
if (!settings.stats && constants_1.IS_SUPPORT_READDIR_WITH_FILE_TYPES) {
|
| 10 |
+
return readdirWithFileTypes(directory, settings);
|
| 11 |
+
}
|
| 12 |
+
return readdir(directory, settings);
|
| 13 |
+
}
|
| 14 |
+
exports.read = read;
|
| 15 |
+
function readdirWithFileTypes(directory, settings) {
|
| 16 |
+
const dirents = settings.fs.readdirSync(directory, { withFileTypes: true });
|
| 17 |
+
return dirents.map((dirent) => {
|
| 18 |
+
const entry = {
|
| 19 |
+
dirent,
|
| 20 |
+
name: dirent.name,
|
| 21 |
+
path: common.joinPathSegments(directory, dirent.name, settings.pathSegmentSeparator)
|
| 22 |
+
};
|
| 23 |
+
if (entry.dirent.isSymbolicLink() && settings.followSymbolicLinks) {
|
| 24 |
+
try {
|
| 25 |
+
const stats = settings.fs.statSync(entry.path);
|
| 26 |
+
entry.dirent = utils.fs.createDirentFromStats(entry.name, stats);
|
| 27 |
+
}
|
| 28 |
+
catch (error) {
|
| 29 |
+
if (settings.throwErrorOnBrokenSymbolicLink) {
|
| 30 |
+
throw error;
|
| 31 |
+
}
|
| 32 |
+
}
|
| 33 |
+
}
|
| 34 |
+
return entry;
|
| 35 |
+
});
|
| 36 |
+
}
|
| 37 |
+
exports.readdirWithFileTypes = readdirWithFileTypes;
|
| 38 |
+
function readdir(directory, settings) {
|
| 39 |
+
const names = settings.fs.readdirSync(directory);
|
| 40 |
+
return names.map((name) => {
|
| 41 |
+
const entryPath = common.joinPathSegments(directory, name, settings.pathSegmentSeparator);
|
| 42 |
+
const stats = fsStat.statSync(entryPath, settings.fsStatSettings);
|
| 43 |
+
const entry = {
|
| 44 |
+
name,
|
| 45 |
+
path: entryPath,
|
| 46 |
+
dirent: utils.fs.createDirentFromStats(name, stats)
|
| 47 |
+
};
|
| 48 |
+
if (settings.stats) {
|
| 49 |
+
entry.stats = stats;
|
| 50 |
+
}
|
| 51 |
+
return entry;
|
| 52 |
+
});
|
| 53 |
+
}
|
| 54 |
+
exports.readdir = readdir;
|
node_modules/@nodelib/fs.scandir/out/settings.d.ts
ADDED
|
@@ -0,0 +1,20 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
import * as fsStat from '@nodelib/fs.stat';
|
| 2 |
+
import * as fs from './adapters/fs';
|
| 3 |
+
export interface Options {
|
| 4 |
+
followSymbolicLinks?: boolean;
|
| 5 |
+
fs?: Partial<fs.FileSystemAdapter>;
|
| 6 |
+
pathSegmentSeparator?: string;
|
| 7 |
+
stats?: boolean;
|
| 8 |
+
throwErrorOnBrokenSymbolicLink?: boolean;
|
| 9 |
+
}
|
| 10 |
+
export default class Settings {
|
| 11 |
+
private readonly _options;
|
| 12 |
+
readonly followSymbolicLinks: boolean;
|
| 13 |
+
readonly fs: fs.FileSystemAdapter;
|
| 14 |
+
readonly pathSegmentSeparator: string;
|
| 15 |
+
readonly stats: boolean;
|
| 16 |
+
readonly throwErrorOnBrokenSymbolicLink: boolean;
|
| 17 |
+
readonly fsStatSettings: fsStat.Settings;
|
| 18 |
+
constructor(_options?: Options);
|
| 19 |
+
private _getValue;
|
| 20 |
+
}
|
node_modules/@nodelib/fs.scandir/out/settings.js
ADDED
|
@@ -0,0 +1,24 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
"use strict";
|
| 2 |
+
Object.defineProperty(exports, "__esModule", { value: true });
|
| 3 |
+
const path = require("path");
|
| 4 |
+
const fsStat = require("@nodelib/fs.stat");
|
| 5 |
+
const fs = require("./adapters/fs");
|
| 6 |
+
class Settings {
|
| 7 |
+
constructor(_options = {}) {
|
| 8 |
+
this._options = _options;
|
| 9 |
+
this.followSymbolicLinks = this._getValue(this._options.followSymbolicLinks, false);
|
| 10 |
+
this.fs = fs.createFileSystemAdapter(this._options.fs);
|
| 11 |
+
this.pathSegmentSeparator = this._getValue(this._options.pathSegmentSeparator, path.sep);
|
| 12 |
+
this.stats = this._getValue(this._options.stats, false);
|
| 13 |
+
this.throwErrorOnBrokenSymbolicLink = this._getValue(this._options.throwErrorOnBrokenSymbolicLink, true);
|
| 14 |
+
this.fsStatSettings = new fsStat.Settings({
|
| 15 |
+
followSymbolicLink: this.followSymbolicLinks,
|
| 16 |
+
fs: this.fs,
|
| 17 |
+
throwErrorOnBrokenSymbolicLink: this.throwErrorOnBrokenSymbolicLink
|
| 18 |
+
});
|
| 19 |
+
}
|
| 20 |
+
_getValue(option, value) {
|
| 21 |
+
return option !== null && option !== void 0 ? option : value;
|
| 22 |
+
}
|
| 23 |
+
}
|
| 24 |
+
exports.default = Settings;
|
node_modules/@nodelib/fs.scandir/out/types/index.d.ts
ADDED
|
@@ -0,0 +1,20 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
/// <reference types="node" />
|
| 2 |
+
import type * as fs from 'fs';
|
| 3 |
+
export interface Entry {
|
| 4 |
+
dirent: Dirent;
|
| 5 |
+
name: string;
|
| 6 |
+
path: string;
|
| 7 |
+
stats?: Stats;
|
| 8 |
+
}
|
| 9 |
+
export declare type Stats = fs.Stats;
|
| 10 |
+
export declare type ErrnoException = NodeJS.ErrnoException;
|
| 11 |
+
export interface Dirent {
|
| 12 |
+
isBlockDevice: () => boolean;
|
| 13 |
+
isCharacterDevice: () => boolean;
|
| 14 |
+
isDirectory: () => boolean;
|
| 15 |
+
isFIFO: () => boolean;
|
| 16 |
+
isFile: () => boolean;
|
| 17 |
+
isSocket: () => boolean;
|
| 18 |
+
isSymbolicLink: () => boolean;
|
| 19 |
+
name: string;
|
| 20 |
+
}
|
node_modules/@nodelib/fs.scandir/out/types/index.js
ADDED
|
@@ -0,0 +1,2 @@
|
|
|
|
|
|
|
|
|
|
| 1 |
+
"use strict";
|
| 2 |
+
Object.defineProperty(exports, "__esModule", { value: true });
|
node_modules/@nodelib/fs.scandir/out/utils/fs.d.ts
ADDED
|
@@ -0,0 +1,2 @@
|
|
|
|
|
|
|
|
|
|
| 1 |
+
import type { Dirent, Stats } from '../types';
|
| 2 |
+
export declare function createDirentFromStats(name: string, stats: Stats): Dirent;
|
node_modules/@nodelib/fs.scandir/out/utils/fs.js
ADDED
|
@@ -0,0 +1,19 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
"use strict";
|
| 2 |
+
Object.defineProperty(exports, "__esModule", { value: true });
|
| 3 |
+
exports.createDirentFromStats = void 0;
|
| 4 |
+
class DirentFromStats {
|
| 5 |
+
constructor(name, stats) {
|
| 6 |
+
this.name = name;
|
| 7 |
+
this.isBlockDevice = stats.isBlockDevice.bind(stats);
|
| 8 |
+
this.isCharacterDevice = stats.isCharacterDevice.bind(stats);
|
| 9 |
+
this.isDirectory = stats.isDirectory.bind(stats);
|
| 10 |
+
this.isFIFO = stats.isFIFO.bind(stats);
|
| 11 |
+
this.isFile = stats.isFile.bind(stats);
|
| 12 |
+
this.isSocket = stats.isSocket.bind(stats);
|
| 13 |
+
this.isSymbolicLink = stats.isSymbolicLink.bind(stats);
|
| 14 |
+
}
|
| 15 |
+
}
|
| 16 |
+
function createDirentFromStats(name, stats) {
|
| 17 |
+
return new DirentFromStats(name, stats);
|
| 18 |
+
}
|
| 19 |
+
exports.createDirentFromStats = createDirentFromStats;
|
node_modules/@nodelib/fs.scandir/out/utils/index.d.ts
ADDED
|
@@ -0,0 +1,2 @@
|
|
|
|
|
|
|
|
|
|
| 1 |
+
import * as fs from './fs';
|
| 2 |
+
export { fs };
|
node_modules/@nodelib/fs.scandir/out/utils/index.js
ADDED
|
@@ -0,0 +1,5 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
"use strict";
|
| 2 |
+
Object.defineProperty(exports, "__esModule", { value: true });
|
| 3 |
+
exports.fs = void 0;
|
| 4 |
+
const fs = require("./fs");
|
| 5 |
+
exports.fs = fs;
|
node_modules/@nodelib/fs.scandir/package.json
ADDED
|
@@ -0,0 +1,44 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
{
|
| 2 |
+
"name": "@nodelib/fs.scandir",
|
| 3 |
+
"version": "2.1.5",
|
| 4 |
+
"description": "List files and directories inside the specified directory",
|
| 5 |
+
"license": "MIT",
|
| 6 |
+
"repository": "https://github.com/nodelib/nodelib/tree/master/packages/fs/fs.scandir",
|
| 7 |
+
"keywords": [
|
| 8 |
+
"NodeLib",
|
| 9 |
+
"fs",
|
| 10 |
+
"FileSystem",
|
| 11 |
+
"file system",
|
| 12 |
+
"scandir",
|
| 13 |
+
"readdir",
|
| 14 |
+
"dirent"
|
| 15 |
+
],
|
| 16 |
+
"engines": {
|
| 17 |
+
"node": ">= 8"
|
| 18 |
+
},
|
| 19 |
+
"files": [
|
| 20 |
+
"out/**",
|
| 21 |
+
"!out/**/*.map",
|
| 22 |
+
"!out/**/*.spec.*"
|
| 23 |
+
],
|
| 24 |
+
"main": "out/index.js",
|
| 25 |
+
"typings": "out/index.d.ts",
|
| 26 |
+
"scripts": {
|
| 27 |
+
"clean": "rimraf {tsconfig.tsbuildinfo,out}",
|
| 28 |
+
"lint": "eslint \"src/**/*.ts\" --cache",
|
| 29 |
+
"compile": "tsc -b .",
|
| 30 |
+
"compile:watch": "tsc -p . --watch --sourceMap",
|
| 31 |
+
"test": "mocha \"out/**/*.spec.js\" -s 0",
|
| 32 |
+
"build": "npm run clean && npm run compile && npm run lint && npm test",
|
| 33 |
+
"watch": "npm run clean && npm run compile:watch"
|
| 34 |
+
},
|
| 35 |
+
"dependencies": {
|
| 36 |
+
"@nodelib/fs.stat": "2.0.5",
|
| 37 |
+
"run-parallel": "^1.1.9"
|
| 38 |
+
},
|
| 39 |
+
"devDependencies": {
|
| 40 |
+
"@nodelib/fs.macchiato": "1.0.4",
|
| 41 |
+
"@types/run-parallel": "^1.1.0"
|
| 42 |
+
},
|
| 43 |
+
"gitHead": "d6a7960d5281d3dd5f8e2efba49bb552d090f562"
|
| 44 |
+
}
|
node_modules/@nodelib/fs.stat/LICENSE
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
The MIT License (MIT)
|
| 2 |
+
|
| 3 |
+
Copyright (c) Denis Malinochkin
|
| 4 |
+
|
| 5 |
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
| 6 |
+
of this software and associated documentation files (the "Software"), to deal
|
| 7 |
+
in the Software without restriction, including without limitation the rights
|
| 8 |
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
| 9 |
+
copies of the Software, and to permit persons to whom the Software is
|
| 10 |
+
furnished to do so, subject to the following conditions:
|
| 11 |
+
|
| 12 |
+
The above copyright notice and this permission notice shall be included in all
|
| 13 |
+
copies or substantial portions of the Software.
|
| 14 |
+
|
| 15 |
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
| 16 |
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
| 17 |
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
| 18 |
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
| 19 |
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
| 20 |
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
| 21 |
+
SOFTWARE.
|
node_modules/@nodelib/fs.stat/README.md
ADDED
|
@@ -0,0 +1,126 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
# @nodelib/fs.stat
|
| 2 |
+
|
| 3 |
+
> Get the status of a file with some features.
|
| 4 |
+
|
| 5 |
+
## :bulb: Highlights
|
| 6 |
+
|
| 7 |
+
Wrapper around standard method `fs.lstat` and `fs.stat` with some features.
|
| 8 |
+
|
| 9 |
+
* :beginner: Normally follows symbolic link.
|
| 10 |
+
* :gear: Can safely work with broken symbolic link.
|
| 11 |
+
|
| 12 |
+
## Install
|
| 13 |
+
|
| 14 |
+
```console
|
| 15 |
+
npm install @nodelib/fs.stat
|
| 16 |
+
```
|
| 17 |
+
|
| 18 |
+
## Usage
|
| 19 |
+
|
| 20 |
+
```ts
|
| 21 |
+
import * as fsStat from '@nodelib/fs.stat';
|
| 22 |
+
|
| 23 |
+
fsStat.stat('path', (error, stats) => { /* … */ });
|
| 24 |
+
```
|
| 25 |
+
|
| 26 |
+
## API
|
| 27 |
+
|
| 28 |
+
### .stat(path, [optionsOrSettings], callback)
|
| 29 |
+
|
| 30 |
+
Returns an instance of `fs.Stats` class for provided path with standard callback-style.
|
| 31 |
+
|
| 32 |
+
```ts
|
| 33 |
+
fsStat.stat('path', (error, stats) => { /* … */ });
|
| 34 |
+
fsStat.stat('path', {}, (error, stats) => { /* … */ });
|
| 35 |
+
fsStat.stat('path', new fsStat.Settings(), (error, stats) => { /* … */ });
|
| 36 |
+
```
|
| 37 |
+
|
| 38 |
+
### .statSync(path, [optionsOrSettings])
|
| 39 |
+
|
| 40 |
+
Returns an instance of `fs.Stats` class for provided path.
|
| 41 |
+
|
| 42 |
+
```ts
|
| 43 |
+
const stats = fsStat.stat('path');
|
| 44 |
+
const stats = fsStat.stat('path', {});
|
| 45 |
+
const stats = fsStat.stat('path', new fsStat.Settings());
|
| 46 |
+
```
|
| 47 |
+
|
| 48 |
+
#### path
|
| 49 |
+
|
| 50 |
+
* Required: `true`
|
| 51 |
+
* Type: `string | Buffer | URL`
|
| 52 |
+
|
| 53 |
+
A path to a file. If a URL is provided, it must use the `file:` protocol.
|
| 54 |
+
|
| 55 |
+
#### optionsOrSettings
|
| 56 |
+
|
| 57 |
+
* Required: `false`
|
| 58 |
+
* Type: `Options | Settings`
|
| 59 |
+
* Default: An instance of `Settings` class
|
| 60 |
+
|
| 61 |
+
An [`Options`](#options) object or an instance of [`Settings`](#settings) class.
|
| 62 |
+
|
| 63 |
+
> :book: When you pass a plain object, an instance of the `Settings` class will be created automatically. If you plan to call the method frequently, use a pre-created instance of the `Settings` class.
|
| 64 |
+
|
| 65 |
+
### Settings([options])
|
| 66 |
+
|
| 67 |
+
A class of full settings of the package.
|
| 68 |
+
|
| 69 |
+
```ts
|
| 70 |
+
const settings = new fsStat.Settings({ followSymbolicLink: false });
|
| 71 |
+
|
| 72 |
+
const stats = fsStat.stat('path', settings);
|
| 73 |
+
```
|
| 74 |
+
|
| 75 |
+
## Options
|
| 76 |
+
|
| 77 |
+
### `followSymbolicLink`
|
| 78 |
+
|
| 79 |
+
* Type: `boolean`
|
| 80 |
+
* Default: `true`
|
| 81 |
+
|
| 82 |
+
Follow symbolic link or not. Call `fs.stat` on symbolic link if `true`.
|
| 83 |
+
|
| 84 |
+
### `markSymbolicLink`
|
| 85 |
+
|
| 86 |
+
* Type: `boolean`
|
| 87 |
+
* Default: `false`
|
| 88 |
+
|
| 89 |
+
Mark symbolic link by setting the return value of `isSymbolicLink` function to always `true` (even after `fs.stat`).
|
| 90 |
+
|
| 91 |
+
> :book: Can be used if you want to know what is hidden behind a symbolic link, but still continue to know that it is a symbolic link.
|
| 92 |
+
|
| 93 |
+
### `throwErrorOnBrokenSymbolicLink`
|
| 94 |
+
|
| 95 |
+
* Type: `boolean`
|
| 96 |
+
* Default: `true`
|
| 97 |
+
|
| 98 |
+
Throw an error when symbolic link is broken if `true` or safely return `lstat` call if `false`.
|
| 99 |
+
|
| 100 |
+
### `fs`
|
| 101 |
+
|
| 102 |
+
* Type: [`FileSystemAdapter`](./src/adapters/fs.ts)
|
| 103 |
+
* Default: A default FS methods
|
| 104 |
+
|
| 105 |
+
By default, the built-in Node.js module (`fs`) is used to work with the file system. You can replace any method with your own.
|
| 106 |
+
|
| 107 |
+
```ts
|
| 108 |
+
interface FileSystemAdapter {
|
| 109 |
+
lstat?: typeof fs.lstat;
|
| 110 |
+
stat?: typeof fs.stat;
|
| 111 |
+
lstatSync?: typeof fs.lstatSync;
|
| 112 |
+
statSync?: typeof fs.statSync;
|
| 113 |
+
}
|
| 114 |
+
|
| 115 |
+
const settings = new fsStat.Settings({
|
| 116 |
+
fs: { lstat: fakeLstat }
|
| 117 |
+
});
|
| 118 |
+
```
|
| 119 |
+
|
| 120 |
+
## Changelog
|
| 121 |
+
|
| 122 |
+
See the [Releases section of our GitHub project](https://github.com/nodelib/nodelib/releases) for changelog for each release version.
|
| 123 |
+
|
| 124 |
+
## License
|
| 125 |
+
|
| 126 |
+
This software is released under the terms of the MIT license.
|
node_modules/@nodelib/fs.stat/out/adapters/fs.d.ts
ADDED
|
@@ -0,0 +1,13 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
/// <reference types="node" />
|
| 2 |
+
import * as fs from 'fs';
|
| 3 |
+
import type { ErrnoException } from '../types';
|
| 4 |
+
export declare type StatAsynchronousMethod = (path: string, callback: (error: ErrnoException | null, stats: fs.Stats) => void) => void;
|
| 5 |
+
export declare type StatSynchronousMethod = (path: string) => fs.Stats;
|
| 6 |
+
export interface FileSystemAdapter {
|
| 7 |
+
lstat: StatAsynchronousMethod;
|
| 8 |
+
stat: StatAsynchronousMethod;
|
| 9 |
+
lstatSync: StatSynchronousMethod;
|
| 10 |
+
statSync: StatSynchronousMethod;
|
| 11 |
+
}
|
| 12 |
+
export declare const FILE_SYSTEM_ADAPTER: FileSystemAdapter;
|
| 13 |
+
export declare function createFileSystemAdapter(fsMethods?: Partial<FileSystemAdapter>): FileSystemAdapter;
|
node_modules/@nodelib/fs.stat/out/adapters/fs.js
ADDED
|
@@ -0,0 +1,17 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
"use strict";
|
| 2 |
+
Object.defineProperty(exports, "__esModule", { value: true });
|
| 3 |
+
exports.createFileSystemAdapter = exports.FILE_SYSTEM_ADAPTER = void 0;
|
| 4 |
+
const fs = require("fs");
|
| 5 |
+
exports.FILE_SYSTEM_ADAPTER = {
|
| 6 |
+
lstat: fs.lstat,
|
| 7 |
+
stat: fs.stat,
|
| 8 |
+
lstatSync: fs.lstatSync,
|
| 9 |
+
statSync: fs.statSync
|
| 10 |
+
};
|
| 11 |
+
function createFileSystemAdapter(fsMethods) {
|
| 12 |
+
if (fsMethods === undefined) {
|
| 13 |
+
return exports.FILE_SYSTEM_ADAPTER;
|
| 14 |
+
}
|
| 15 |
+
return Object.assign(Object.assign({}, exports.FILE_SYSTEM_ADAPTER), fsMethods);
|
| 16 |
+
}
|
| 17 |
+
exports.createFileSystemAdapter = createFileSystemAdapter;
|
node_modules/@nodelib/fs.stat/out/index.d.ts
ADDED
|
@@ -0,0 +1,12 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
import type { FileSystemAdapter, StatAsynchronousMethod, StatSynchronousMethod } from './adapters/fs';
|
| 2 |
+
import * as async from './providers/async';
|
| 3 |
+
import Settings, { Options } from './settings';
|
| 4 |
+
import type { Stats } from './types';
|
| 5 |
+
declare type AsyncCallback = async.AsyncCallback;
|
| 6 |
+
declare function stat(path: string, callback: AsyncCallback): void;
|
| 7 |
+
declare function stat(path: string, optionsOrSettings: Options | Settings, callback: AsyncCallback): void;
|
| 8 |
+
declare namespace stat {
|
| 9 |
+
function __promisify__(path: string, optionsOrSettings?: Options | Settings): Promise<Stats>;
|
| 10 |
+
}
|
| 11 |
+
declare function statSync(path: string, optionsOrSettings?: Options | Settings): Stats;
|
| 12 |
+
export { Settings, stat, statSync, AsyncCallback, FileSystemAdapter, StatAsynchronousMethod, StatSynchronousMethod, Options, Stats };
|
node_modules/@nodelib/fs.stat/out/index.js
ADDED
|
@@ -0,0 +1,26 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
"use strict";
|
| 2 |
+
Object.defineProperty(exports, "__esModule", { value: true });
|
| 3 |
+
exports.statSync = exports.stat = exports.Settings = void 0;
|
| 4 |
+
const async = require("./providers/async");
|
| 5 |
+
const sync = require("./providers/sync");
|
| 6 |
+
const settings_1 = require("./settings");
|
| 7 |
+
exports.Settings = settings_1.default;
|
| 8 |
+
function stat(path, optionsOrSettingsOrCallback, callback) {
|
| 9 |
+
if (typeof optionsOrSettingsOrCallback === 'function') {
|
| 10 |
+
async.read(path, getSettings(), optionsOrSettingsOrCallback);
|
| 11 |
+
return;
|
| 12 |
+
}
|
| 13 |
+
async.read(path, getSettings(optionsOrSettingsOrCallback), callback);
|
| 14 |
+
}
|
| 15 |
+
exports.stat = stat;
|
| 16 |
+
function statSync(path, optionsOrSettings) {
|
| 17 |
+
const settings = getSettings(optionsOrSettings);
|
| 18 |
+
return sync.read(path, settings);
|
| 19 |
+
}
|
| 20 |
+
exports.statSync = statSync;
|
| 21 |
+
function getSettings(settingsOrOptions = {}) {
|
| 22 |
+
if (settingsOrOptions instanceof settings_1.default) {
|
| 23 |
+
return settingsOrOptions;
|
| 24 |
+
}
|
| 25 |
+
return new settings_1.default(settingsOrOptions);
|
| 26 |
+
}
|
node_modules/@nodelib/fs.stat/out/providers/async.d.ts
ADDED
|
@@ -0,0 +1,4 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
import type Settings from '../settings';
|
| 2 |
+
import type { ErrnoException, Stats } from '../types';
|
| 3 |
+
export declare type AsyncCallback = (error: ErrnoException, stats: Stats) => void;
|
| 4 |
+
export declare function read(path: string, settings: Settings, callback: AsyncCallback): void;
|
node_modules/@nodelib/fs.stat/out/providers/async.js
ADDED
|
@@ -0,0 +1,36 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
"use strict";
|
| 2 |
+
Object.defineProperty(exports, "__esModule", { value: true });
|
| 3 |
+
exports.read = void 0;
|
| 4 |
+
function read(path, settings, callback) {
|
| 5 |
+
settings.fs.lstat(path, (lstatError, lstat) => {
|
| 6 |
+
if (lstatError !== null) {
|
| 7 |
+
callFailureCallback(callback, lstatError);
|
| 8 |
+
return;
|
| 9 |
+
}
|
| 10 |
+
if (!lstat.isSymbolicLink() || !settings.followSymbolicLink) {
|
| 11 |
+
callSuccessCallback(callback, lstat);
|
| 12 |
+
return;
|
| 13 |
+
}
|
| 14 |
+
settings.fs.stat(path, (statError, stat) => {
|
| 15 |
+
if (statError !== null) {
|
| 16 |
+
if (settings.throwErrorOnBrokenSymbolicLink) {
|
| 17 |
+
callFailureCallback(callback, statError);
|
| 18 |
+
return;
|
| 19 |
+
}
|
| 20 |
+
callSuccessCallback(callback, lstat);
|
| 21 |
+
return;
|
| 22 |
+
}
|
| 23 |
+
if (settings.markSymbolicLink) {
|
| 24 |
+
stat.isSymbolicLink = () => true;
|
| 25 |
+
}
|
| 26 |
+
callSuccessCallback(callback, stat);
|
| 27 |
+
});
|
| 28 |
+
});
|
| 29 |
+
}
|
| 30 |
+
exports.read = read;
|
| 31 |
+
function callFailureCallback(callback, error) {
|
| 32 |
+
callback(error);
|
| 33 |
+
}
|
| 34 |
+
function callSuccessCallback(callback, result) {
|
| 35 |
+
callback(null, result);
|
| 36 |
+
}
|
node_modules/@nodelib/fs.stat/out/providers/sync.d.ts
ADDED
|
@@ -0,0 +1,3 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
import type Settings from '../settings';
|
| 2 |
+
import type { Stats } from '../types';
|
| 3 |
+
export declare function read(path: string, settings: Settings): Stats;
|
node_modules/@nodelib/fs.stat/out/providers/sync.js
ADDED
|
@@ -0,0 +1,23 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
"use strict";
|
| 2 |
+
Object.defineProperty(exports, "__esModule", { value: true });
|
| 3 |
+
exports.read = void 0;
|
| 4 |
+
function read(path, settings) {
|
| 5 |
+
const lstat = settings.fs.lstatSync(path);
|
| 6 |
+
if (!lstat.isSymbolicLink() || !settings.followSymbolicLink) {
|
| 7 |
+
return lstat;
|
| 8 |
+
}
|
| 9 |
+
try {
|
| 10 |
+
const stat = settings.fs.statSync(path);
|
| 11 |
+
if (settings.markSymbolicLink) {
|
| 12 |
+
stat.isSymbolicLink = () => true;
|
| 13 |
+
}
|
| 14 |
+
return stat;
|
| 15 |
+
}
|
| 16 |
+
catch (error) {
|
| 17 |
+
if (!settings.throwErrorOnBrokenSymbolicLink) {
|
| 18 |
+
return lstat;
|
| 19 |
+
}
|
| 20 |
+
throw error;
|
| 21 |
+
}
|
| 22 |
+
}
|
| 23 |
+
exports.read = read;
|
node_modules/@nodelib/fs.stat/out/settings.d.ts
ADDED
|
@@ -0,0 +1,16 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
import * as fs from './adapters/fs';
|
| 2 |
+
export interface Options {
|
| 3 |
+
followSymbolicLink?: boolean;
|
| 4 |
+
fs?: Partial<fs.FileSystemAdapter>;
|
| 5 |
+
markSymbolicLink?: boolean;
|
| 6 |
+
throwErrorOnBrokenSymbolicLink?: boolean;
|
| 7 |
+
}
|
| 8 |
+
export default class Settings {
|
| 9 |
+
private readonly _options;
|
| 10 |
+
readonly followSymbolicLink: boolean;
|
| 11 |
+
readonly fs: fs.FileSystemAdapter;
|
| 12 |
+
readonly markSymbolicLink: boolean;
|
| 13 |
+
readonly throwErrorOnBrokenSymbolicLink: boolean;
|
| 14 |
+
constructor(_options?: Options);
|
| 15 |
+
private _getValue;
|
| 16 |
+
}
|
node_modules/@nodelib/fs.stat/out/settings.js
ADDED
|
@@ -0,0 +1,16 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
"use strict";
|
| 2 |
+
Object.defineProperty(exports, "__esModule", { value: true });
|
| 3 |
+
const fs = require("./adapters/fs");
|
| 4 |
+
class Settings {
|
| 5 |
+
constructor(_options = {}) {
|
| 6 |
+
this._options = _options;
|
| 7 |
+
this.followSymbolicLink = this._getValue(this._options.followSymbolicLink, true);
|
| 8 |
+
this.fs = fs.createFileSystemAdapter(this._options.fs);
|
| 9 |
+
this.markSymbolicLink = this._getValue(this._options.markSymbolicLink, false);
|
| 10 |
+
this.throwErrorOnBrokenSymbolicLink = this._getValue(this._options.throwErrorOnBrokenSymbolicLink, true);
|
| 11 |
+
}
|
| 12 |
+
_getValue(option, value) {
|
| 13 |
+
return option !== null && option !== void 0 ? option : value;
|
| 14 |
+
}
|
| 15 |
+
}
|
| 16 |
+
exports.default = Settings;
|
node_modules/@nodelib/fs.stat/out/types/index.d.ts
ADDED
|
@@ -0,0 +1,4 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
/// <reference types="node" />
|
| 2 |
+
import type * as fs from 'fs';
|
| 3 |
+
export declare type Stats = fs.Stats;
|
| 4 |
+
export declare type ErrnoException = NodeJS.ErrnoException;
|