keri-ts 0.2.3 → 0.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +57 -8
- package/esm/app/cli/agent.js +0 -19
- package/esm/app/cli/annotate.js +7 -2
- package/esm/app/cli/benchmark.js +210 -0
- package/esm/app/cli/cli.js +50 -52
- package/esm/app/cli/command-definitions.js +258 -6
- package/esm/app/cli/common/existing.js +40 -0
- package/esm/app/cli/common/parsing.js +20 -0
- package/esm/app/cli/export.js +51 -0
- package/esm/app/cli/incept.js +106 -0
- package/esm/app/cli/index.js +2 -0
- package/esm/app/cli/init.js +72 -41
- package/esm/app/configing.js +261 -0
- package/esm/app/habbing.js +386 -0
- package/esm/app/index.js +3 -0
- package/esm/app/keeping.js +321 -0
- package/esm/app/version.js +2 -2
- package/esm/db/basing.js +66 -1
- package/esm/db/core/lmdber.js +13 -7
- package/esm/db/core/path-manager.js +193 -169
- package/esm/db/index.js +1 -0
- package/esm/db/keeping.js +214 -0
- package/esm/deps/jsr.io/@std/internal/1.0.12/_os.js +12 -0
- package/esm/deps/jsr.io/@std/internal/1.0.12/os.js +5 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/_common/assert_path.js +7 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/_common/basename.js +40 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/_common/common.js +23 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/_common/constants.js +46 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/_common/dirname.js +8 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/_common/format.js +19 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/_common/from_file_url.js +9 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/_common/glob_to_reg_exp.js +235 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/_common/normalize.js +8 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/_common/normalize_string.js +77 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/_common/relative.js +9 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/_common/strip_trailing_separators.js +19 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/_common/to_file_url.js +15 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/basename.js +35 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/common.js +33 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/constants.js +17 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/dirname.js +28 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/extname.js +28 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/format.js +27 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/from_file_url.js +28 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/glob_to_regexp.js +83 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/is_absolute.js +28 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/is_glob.js +42 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/join.js +29 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/join_globs.js +34 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/mod.js +216 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/normalize.js +32 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/normalize_glob.js +35 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/parse.js +39 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/posix/_util.js +8 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/posix/basename.js +52 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/posix/constants.js +14 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/posix/dirname.js +64 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/posix/extname.js +93 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/posix/format.js +28 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/posix/from_file_url.js +21 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/posix/glob_to_regexp.js +82 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/posix/is_absolute.js +23 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/posix/join.js +45 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/posix/join_globs.js +40 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/posix/normalize.js +58 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/posix/normalize_glob.js +32 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/posix/parse.js +115 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/posix/relative.js +106 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/posix/resolve.js +59 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/posix/to_file_url.js +27 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/posix/to_namespaced_path.js +20 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/relative.js +30 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/resolve.js +30 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/to_file_url.js +28 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/to_namespaced_path.js +29 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/types.js +3 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/windows/_util.js +15 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/windows/basename.js +47 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/windows/constants.js +14 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/windows/dirname.js +113 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/windows/extname.js +82 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/windows/format.js +28 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/windows/from_file_url.js +30 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/windows/glob_to_regexp.js +82 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/windows/is_absolute.js +38 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/windows/join.js +77 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/windows/join_globs.js +41 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/windows/normalize.js +135 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/windows/normalize_glob.js +32 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/windows/parse.js +176 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/windows/relative.js +131 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/windows/resolve.js +154 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/windows/to_file_url.js +34 -0
- package/esm/deps/jsr.io/@std/path/1.1.4/windows/to_namespaced_path.js +49 -0
- package/package.json +4 -2
- package/types/app/cli/agent.d.ts.map +1 -1
- package/types/app/cli/annotate.d.ts.map +1 -1
- package/types/app/cli/benchmark.d.ts +11 -0
- package/types/app/cli/benchmark.d.ts.map +1 -0
- package/types/app/cli/cli.d.ts.map +1 -1
- package/types/app/cli/command-definitions.d.ts +5 -2
- package/types/app/cli/command-definitions.d.ts.map +1 -1
- package/types/app/cli/command-types.d.ts +12 -0
- package/types/app/cli/command-types.d.ts.map +1 -1
- package/types/app/cli/common/existing.d.ts +4 -0
- package/types/app/cli/common/existing.d.ts.map +1 -0
- package/types/app/cli/common/parsing.d.ts +15 -0
- package/types/app/cli/common/parsing.d.ts.map +1 -0
- package/types/app/cli/export.d.ts +8 -0
- package/types/app/cli/export.d.ts.map +1 -0
- package/types/app/cli/incept.d.ts +8 -0
- package/types/app/cli/incept.d.ts.map +1 -0
- package/types/app/cli/index.d.ts +2 -0
- package/types/app/cli/index.d.ts.map +1 -1
- package/types/app/cli/init.d.ts +5 -0
- package/types/app/cli/init.d.ts.map +1 -1
- package/types/app/configing.d.ts +57 -0
- package/types/app/configing.d.ts.map +1 -0
- package/types/app/habbing.d.ts +107 -0
- package/types/app/habbing.d.ts.map +1 -0
- package/types/app/index.d.ts +3 -0
- package/types/app/index.d.ts.map +1 -1
- package/types/app/keeping.d.ts +72 -0
- package/types/app/keeping.d.ts.map +1 -0
- package/types/app/version.d.ts +2 -2
- package/types/db/basing.d.ts +16 -1
- package/types/db/basing.d.ts.map +1 -1
- package/types/db/core/lmdber.d.ts +8 -4
- package/types/db/core/lmdber.d.ts.map +1 -1
- package/types/db/core/path-manager.d.ts +88 -24
- package/types/db/core/path-manager.d.ts.map +1 -1
- package/types/db/index.d.ts +1 -0
- package/types/db/index.d.ts.map +1 -1
- package/types/db/keeping.d.ts +73 -0
- package/types/db/keeping.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/internal/1.0.12/_os.d.ts +2 -0
- package/types/deps/jsr.io/@std/internal/1.0.12/_os.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/internal/1.0.12/os.d.ts +3 -0
- package/types/deps/jsr.io/@std/internal/1.0.12/os.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/_common/assert_path.d.ts +2 -0
- package/types/deps/jsr.io/@std/path/1.1.4/_common/assert_path.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/_common/basename.d.ts +4 -0
- package/types/deps/jsr.io/@std/path/1.1.4/_common/basename.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/_common/common.d.ts +2 -0
- package/types/deps/jsr.io/@std/path/1.1.4/_common/common.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/_common/constants.d.ts +40 -0
- package/types/deps/jsr.io/@std/path/1.1.4/_common/constants.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/_common/dirname.d.ts +2 -0
- package/types/deps/jsr.io/@std/path/1.1.4/_common/dirname.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/_common/format.d.ts +4 -0
- package/types/deps/jsr.io/@std/path/1.1.4/_common/format.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/_common/from_file_url.d.ts +2 -0
- package/types/deps/jsr.io/@std/path/1.1.4/_common/from_file_url.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/_common/glob_to_reg_exp.d.ts +35 -0
- package/types/deps/jsr.io/@std/path/1.1.4/_common/glob_to_reg_exp.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/_common/normalize.d.ts +2 -0
- package/types/deps/jsr.io/@std/path/1.1.4/_common/normalize.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/_common/normalize_string.d.ts +2 -0
- package/types/deps/jsr.io/@std/path/1.1.4/_common/normalize_string.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/_common/relative.d.ts +2 -0
- package/types/deps/jsr.io/@std/path/1.1.4/_common/relative.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/_common/strip_trailing_separators.d.ts +2 -0
- package/types/deps/jsr.io/@std/path/1.1.4/_common/strip_trailing_separators.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/_common/to_file_url.d.ts +2 -0
- package/types/deps/jsr.io/@std/path/1.1.4/_common/to_file_url.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/basename.d.ts +27 -0
- package/types/deps/jsr.io/@std/path/1.1.4/basename.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/common.d.ts +28 -0
- package/types/deps/jsr.io/@std/path/1.1.4/common.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/constants.d.ts +15 -0
- package/types/deps/jsr.io/@std/path/1.1.4/constants.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/dirname.d.ts +22 -0
- package/types/deps/jsr.io/@std/path/1.1.4/dirname.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/extname.d.ts +22 -0
- package/types/deps/jsr.io/@std/path/1.1.4/extname.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/format.d.ts +22 -0
- package/types/deps/jsr.io/@std/path/1.1.4/format.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/from_file_url.d.ts +22 -0
- package/types/deps/jsr.io/@std/path/1.1.4/from_file_url.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/glob_to_regexp.d.ts +77 -0
- package/types/deps/jsr.io/@std/path/1.1.4/glob_to_regexp.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/is_absolute.d.ts +22 -0
- package/types/deps/jsr.io/@std/path/1.1.4/is_absolute.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/is_glob.d.ts +17 -0
- package/types/deps/jsr.io/@std/path/1.1.4/is_glob.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/join.d.ts +23 -0
- package/types/deps/jsr.io/@std/path/1.1.4/join.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/join_globs.d.ts +28 -0
- package/types/deps/jsr.io/@std/path/1.1.4/join_globs.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/mod.d.ts +213 -0
- package/types/deps/jsr.io/@std/path/1.1.4/mod.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/normalize.d.ts +26 -0
- package/types/deps/jsr.io/@std/path/1.1.4/normalize.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/normalize_glob.d.ts +29 -0
- package/types/deps/jsr.io/@std/path/1.1.4/normalize_glob.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/parse.d.ts +35 -0
- package/types/deps/jsr.io/@std/path/1.1.4/parse.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/_util.d.ts +2 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/_util.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/basename.d.ts +39 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/basename.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/constants.d.ts +13 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/constants.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/dirname.d.ts +30 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/dirname.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/extname.d.ts +37 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/extname.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/format.d.ts +24 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/format.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/from_file_url.d.ts +16 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/from_file_url.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/glob_to_regexp.d.ts +72 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/glob_to_regexp.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/is_absolute.d.ts +17 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/is_absolute.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/join.d.ts +31 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/join.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/join_globs.d.ts +20 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/join_globs.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/normalize.d.ts +37 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/normalize.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/normalize_glob.d.ts +20 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/normalize_glob.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/parse.d.ts +25 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/parse.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/relative.d.ts +20 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/relative.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/resolve.d.ts +17 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/resolve.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/to_file_url.d.ts +17 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/to_file_url.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/to_namespaced_path.d.ts +16 -0
- package/types/deps/jsr.io/@std/path/1.1.4/posix/to_namespaced_path.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/relative.d.ts +24 -0
- package/types/deps/jsr.io/@std/path/1.1.4/relative.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/resolve.d.ts +22 -0
- package/types/deps/jsr.io/@std/path/1.1.4/resolve.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/to_file_url.d.ts +22 -0
- package/types/deps/jsr.io/@std/path/1.1.4/to_file_url.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/to_namespaced_path.d.ts +21 -0
- package/types/deps/jsr.io/@std/path/1.1.4/to_namespaced_path.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/types.d.ts +38 -0
- package/types/deps/jsr.io/@std/path/1.1.4/types.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/_util.d.ts +4 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/_util.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/basename.d.ts +22 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/basename.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/constants.d.ts +13 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/constants.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/dirname.d.ts +17 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/dirname.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/extname.d.ts +17 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/extname.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/format.d.ts +24 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/format.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/from_file_url.d.ts +18 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/from_file_url.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/glob_to_regexp.d.ts +71 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/glob_to_regexp.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/is_absolute.d.ts +17 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/is_absolute.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/join.d.ts +18 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/join.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/join_globs.d.ts +21 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/join_globs.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/normalize.d.ts +19 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/normalize.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/normalize_glob.d.ts +20 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/normalize_glob.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/parse.d.ts +25 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/parse.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/relative.d.ts +23 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/relative.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/resolve.d.ts +17 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/resolve.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/to_file_url.d.ts +17 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/to_file_url.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/to_namespaced_path.d.ts +17 -0
- package/types/deps/jsr.io/@std/path/1.1.4/windows/to_namespaced_path.d.ts.map +1 -0
- package/esm/app/cli/stub-commands.js +0 -61
- package/types/app/cli/stub-commands.d.ts +0 -6
- package/types/app/cli/stub-commands.d.ts.map +0 -1
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
// Copyright 2018-2025 the Deno authors. MIT license.
|
|
2
|
+
// Copyright the Browserify authors. MIT License.
|
|
3
|
+
// Ported from https://github.com/browserify/path-browserify/
|
|
4
|
+
// This module is browser compatible.
|
|
5
|
+
import { CHAR_DOT, CHAR_FORWARD_SLASH } from "./constants.js";
|
|
6
|
+
// Resolves . and .. elements in a path with directory names
|
|
7
|
+
export function normalizeString(path, allowAboveRoot, separator, isPathSeparator) {
|
|
8
|
+
let res = "";
|
|
9
|
+
let lastSegmentLength = 0;
|
|
10
|
+
let lastSlash = -1;
|
|
11
|
+
let dots = 0;
|
|
12
|
+
let code;
|
|
13
|
+
for (let i = 0; i <= path.length; ++i) {
|
|
14
|
+
if (i < path.length)
|
|
15
|
+
code = path.charCodeAt(i);
|
|
16
|
+
else if (isPathSeparator(code))
|
|
17
|
+
break;
|
|
18
|
+
else
|
|
19
|
+
code = CHAR_FORWARD_SLASH;
|
|
20
|
+
if (isPathSeparator(code)) {
|
|
21
|
+
if (lastSlash === i - 1 || dots === 1) {
|
|
22
|
+
// NOOP
|
|
23
|
+
}
|
|
24
|
+
else if (lastSlash !== i - 1 && dots === 2) {
|
|
25
|
+
if (res.length < 2 ||
|
|
26
|
+
lastSegmentLength !== 2 ||
|
|
27
|
+
res.charCodeAt(res.length - 1) !== CHAR_DOT ||
|
|
28
|
+
res.charCodeAt(res.length - 2) !== CHAR_DOT) {
|
|
29
|
+
if (res.length > 2) {
|
|
30
|
+
const lastSlashIndex = res.lastIndexOf(separator);
|
|
31
|
+
if (lastSlashIndex === -1) {
|
|
32
|
+
res = "";
|
|
33
|
+
lastSegmentLength = 0;
|
|
34
|
+
}
|
|
35
|
+
else {
|
|
36
|
+
res = res.slice(0, lastSlashIndex);
|
|
37
|
+
lastSegmentLength = res.length - 1 - res.lastIndexOf(separator);
|
|
38
|
+
}
|
|
39
|
+
lastSlash = i;
|
|
40
|
+
dots = 0;
|
|
41
|
+
continue;
|
|
42
|
+
}
|
|
43
|
+
else if (res.length === 2 || res.length === 1) {
|
|
44
|
+
res = "";
|
|
45
|
+
lastSegmentLength = 0;
|
|
46
|
+
lastSlash = i;
|
|
47
|
+
dots = 0;
|
|
48
|
+
continue;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
if (allowAboveRoot) {
|
|
52
|
+
if (res.length > 0)
|
|
53
|
+
res += `${separator}..`;
|
|
54
|
+
else
|
|
55
|
+
res = "..";
|
|
56
|
+
lastSegmentLength = 2;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
else {
|
|
60
|
+
if (res.length > 0)
|
|
61
|
+
res += separator + path.slice(lastSlash + 1, i);
|
|
62
|
+
else
|
|
63
|
+
res = path.slice(lastSlash + 1, i);
|
|
64
|
+
lastSegmentLength = i - lastSlash - 1;
|
|
65
|
+
}
|
|
66
|
+
lastSlash = i;
|
|
67
|
+
dots = 0;
|
|
68
|
+
}
|
|
69
|
+
else if (code === CHAR_DOT && dots !== -1) {
|
|
70
|
+
++dots;
|
|
71
|
+
}
|
|
72
|
+
else {
|
|
73
|
+
dots = -1;
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
return res;
|
|
77
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
// Copyright 2018-2025 the Deno authors. MIT license.
|
|
2
|
+
// Copyright the Browserify authors. MIT License.
|
|
3
|
+
// Ported from https://github.com/browserify/path-browserify/
|
|
4
|
+
// This module is browser compatible.
|
|
5
|
+
export function stripTrailingSeparators(segment, isSep) {
|
|
6
|
+
if (segment.length <= 1) {
|
|
7
|
+
return segment;
|
|
8
|
+
}
|
|
9
|
+
let end = segment.length;
|
|
10
|
+
for (let i = segment.length - 1; i > 0; i--) {
|
|
11
|
+
if (isSep(segment.charCodeAt(i))) {
|
|
12
|
+
end = i;
|
|
13
|
+
}
|
|
14
|
+
else {
|
|
15
|
+
break;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
return segment.slice(0, end);
|
|
19
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
// Copyright 2018-2025 the Deno authors. MIT license.
|
|
2
|
+
// This module is browser compatible.
|
|
3
|
+
const WHITESPACE_ENCODINGS = {
|
|
4
|
+
"\u0009": "%09",
|
|
5
|
+
"\u000A": "%0A",
|
|
6
|
+
"\u000B": "%0B",
|
|
7
|
+
"\u000C": "%0C",
|
|
8
|
+
"\u000D": "%0D",
|
|
9
|
+
"\u0020": "%20",
|
|
10
|
+
};
|
|
11
|
+
export function encodeWhitespace(string) {
|
|
12
|
+
return string.replaceAll(/[\s]/g, (c) => {
|
|
13
|
+
return WHITESPACE_ENCODINGS[c] ?? c;
|
|
14
|
+
});
|
|
15
|
+
}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
// Copyright 2018-2025 the Deno authors. MIT license.
|
|
2
|
+
// This module is browser compatible.
|
|
3
|
+
import { isWindows } from "../../internal/1.0.12/os.js";
|
|
4
|
+
import { basename as posixBasename } from "./posix/basename.js";
|
|
5
|
+
import { basename as windowsBasename } from "./windows/basename.js";
|
|
6
|
+
/**
|
|
7
|
+
* Return the last portion of a path.
|
|
8
|
+
*
|
|
9
|
+
* The trailing directory separators are ignored, and optional suffix is
|
|
10
|
+
* removed.
|
|
11
|
+
*
|
|
12
|
+
* @example Usage
|
|
13
|
+
* ```ts
|
|
14
|
+
* import { basename } from "@std/path/basename";
|
|
15
|
+
* import { assertEquals } from "@std/assert";
|
|
16
|
+
*
|
|
17
|
+
* if (Deno.build.os === "windows") {
|
|
18
|
+
* assertEquals(basename("C:\\user\\Documents\\image.png"), "image.png");
|
|
19
|
+
* assertEquals(basename(new URL("file:///C:/user/Documents/image.png")), "image.png");
|
|
20
|
+
* } else {
|
|
21
|
+
* assertEquals(basename("/home/user/Documents/image.png"), "image.png");
|
|
22
|
+
* assertEquals(basename(new URL("file:///home/user/Documents/image.png")), "image.png");
|
|
23
|
+
* }
|
|
24
|
+
* ```
|
|
25
|
+
*
|
|
26
|
+
* @param path Path to extract the name from.
|
|
27
|
+
* @param suffix Suffix to remove from extracted name.
|
|
28
|
+
*
|
|
29
|
+
* @returns The basename of the path.
|
|
30
|
+
*/
|
|
31
|
+
export function basename(path, suffix = "") {
|
|
32
|
+
return isWindows
|
|
33
|
+
? windowsBasename(path, suffix)
|
|
34
|
+
: posixBasename(path, suffix);
|
|
35
|
+
}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
// Copyright 2018-2025 the Deno authors. MIT license.
|
|
2
|
+
// This module is browser compatible.
|
|
3
|
+
import { common as _common } from "./_common/common.js";
|
|
4
|
+
import { SEPARATOR } from "./constants.js";
|
|
5
|
+
/**
|
|
6
|
+
* Determines the common path from a set of paths for the given OS.
|
|
7
|
+
*
|
|
8
|
+
* @param paths Paths to search for common path.
|
|
9
|
+
* @returns The common path.
|
|
10
|
+
*
|
|
11
|
+
* @example Usage
|
|
12
|
+
* ```ts
|
|
13
|
+
* import { common } from "@std/path/common";
|
|
14
|
+
* import { assertEquals } from "@std/assert";
|
|
15
|
+
*
|
|
16
|
+
* if (Deno.build.os === "windows") {
|
|
17
|
+
* const path = common([
|
|
18
|
+
* "C:\\deno\\std\\path\\mod.ts",
|
|
19
|
+
* "C:\\deno\\std\\fs\\mod.ts"
|
|
20
|
+
* ]);
|
|
21
|
+
* assertEquals(path, "C:\\deno\\std\\");
|
|
22
|
+
* } else {
|
|
23
|
+
* const path = common([
|
|
24
|
+
* "./deno/std/path/mod.ts",
|
|
25
|
+
* "./deno/std/fs/mod.ts"
|
|
26
|
+
* ]);
|
|
27
|
+
* assertEquals(path, "./deno/std/");
|
|
28
|
+
* }
|
|
29
|
+
* ```
|
|
30
|
+
*/
|
|
31
|
+
export function common(paths) {
|
|
32
|
+
return _common(paths, SEPARATOR);
|
|
33
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
// Copyright 2018-2025 the Deno authors. MIT license.
|
|
2
|
+
// This module is browser compatible.
|
|
3
|
+
import { isWindows } from "../../internal/1.0.12/os.js";
|
|
4
|
+
/**
|
|
5
|
+
* The character used to separate entries in the PATH environment variable.
|
|
6
|
+
* On Windows, this is `;`. On all other platforms, this is `:`.
|
|
7
|
+
*/
|
|
8
|
+
export const DELIMITER = isWindows ? ";" : ":";
|
|
9
|
+
/**
|
|
10
|
+
* The character used to separate components of a file path.
|
|
11
|
+
* On Windows, this is `\`. On all other platforms, this is `/`.
|
|
12
|
+
*/
|
|
13
|
+
export const SEPARATOR = isWindows ? "\\" : "/";
|
|
14
|
+
/**
|
|
15
|
+
* A regular expression that matches one or more path separators.
|
|
16
|
+
*/
|
|
17
|
+
export const SEPARATOR_PATTERN = isWindows ? /[\\/]+/ : /\/+/;
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
// Copyright 2018-2025 the Deno authors. MIT license.
|
|
2
|
+
// This module is browser compatible.
|
|
3
|
+
import { isWindows } from "../../internal/1.0.12/os.js";
|
|
4
|
+
import { dirname as posixDirname } from "./posix/dirname.js";
|
|
5
|
+
import { dirname as windowsDirname } from "./windows/dirname.js";
|
|
6
|
+
/**
|
|
7
|
+
* Return the directory path of a path.
|
|
8
|
+
*
|
|
9
|
+
* @example Usage
|
|
10
|
+
* ```ts
|
|
11
|
+
* import { dirname } from "@std/path/dirname";
|
|
12
|
+
* import { assertEquals } from "@std/assert";
|
|
13
|
+
*
|
|
14
|
+
* if (Deno.build.os === "windows") {
|
|
15
|
+
* assertEquals(dirname("C:\\home\\user\\Documents\\image.png"), "C:\\home\\user\\Documents");
|
|
16
|
+
* assertEquals(dirname(new URL("file:///C:/home/user/Documents/image.png")), "C:\\home\\user\\Documents");
|
|
17
|
+
* } else {
|
|
18
|
+
* assertEquals(dirname("/home/user/Documents/image.png"), "/home/user/Documents");
|
|
19
|
+
* assertEquals(dirname(new URL("file:///home/user/Documents/image.png")), "/home/user/Documents");
|
|
20
|
+
* }
|
|
21
|
+
* ```
|
|
22
|
+
*
|
|
23
|
+
* @param path Path to extract the directory from.
|
|
24
|
+
* @returns The directory path.
|
|
25
|
+
*/
|
|
26
|
+
export function dirname(path) {
|
|
27
|
+
return isWindows ? windowsDirname(path) : posixDirname(path);
|
|
28
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
// Copyright 2018-2025 the Deno authors. MIT license.
|
|
2
|
+
// This module is browser compatible.
|
|
3
|
+
import { isWindows } from "../../internal/1.0.12/os.js";
|
|
4
|
+
import { extname as posixExtname } from "./posix/extname.js";
|
|
5
|
+
import { extname as windowsExtname } from "./windows/extname.js";
|
|
6
|
+
/**
|
|
7
|
+
* Return the extension of the path with leading period (".").
|
|
8
|
+
*
|
|
9
|
+
* @example Usage
|
|
10
|
+
* ```ts
|
|
11
|
+
* import { extname } from "@std/path/extname";
|
|
12
|
+
* import { assertEquals } from "@std/assert";
|
|
13
|
+
*
|
|
14
|
+
* if (Deno.build.os === "windows") {
|
|
15
|
+
* assertEquals(extname("C:\\home\\user\\Documents\\image.png"), ".png");
|
|
16
|
+
* assertEquals(extname(new URL("file:///C:/home/user/Documents/image.png")), ".png");
|
|
17
|
+
* } else {
|
|
18
|
+
* assertEquals(extname("/home/user/Documents/image.png"), ".png");
|
|
19
|
+
* assertEquals(extname(new URL("file:///home/user/Documents/image.png")), ".png");
|
|
20
|
+
* }
|
|
21
|
+
* ```
|
|
22
|
+
*
|
|
23
|
+
* @param path Path with extension.
|
|
24
|
+
* @returns The file extension. E.g. returns `.ts` for `file.ts`.
|
|
25
|
+
*/
|
|
26
|
+
export function extname(path) {
|
|
27
|
+
return isWindows ? windowsExtname(path) : posixExtname(path);
|
|
28
|
+
}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
// Copyright 2018-2025 the Deno authors. MIT license.
|
|
2
|
+
// This module is browser compatible.
|
|
3
|
+
import { isWindows } from "../../internal/1.0.12/os.js";
|
|
4
|
+
import { format as posixFormat } from "./posix/format.js";
|
|
5
|
+
import { format as windowsFormat } from "./windows/format.js";
|
|
6
|
+
/**
|
|
7
|
+
* Generate a path from a {@linkcode ParsedPath} object. It does the
|
|
8
|
+
* opposite of {@linkcode https://jsr.io/@std/path/doc/~/parse | parse()}.
|
|
9
|
+
*
|
|
10
|
+
* @example Usage
|
|
11
|
+
* ```ts
|
|
12
|
+
* import { format } from "@std/path/format";
|
|
13
|
+
* import { assertEquals } from "@std/assert";
|
|
14
|
+
*
|
|
15
|
+
* if (Deno.build.os === "windows") {
|
|
16
|
+
* assertEquals(format({ dir: "C:\\path\\to", base: "script.ts" }), "C:\\path\\to\\script.ts");
|
|
17
|
+
* } else {
|
|
18
|
+
* assertEquals(format({ dir: "/path/to/dir", base: "script.ts" }), "/path/to/dir/script.ts");
|
|
19
|
+
* }
|
|
20
|
+
* ```
|
|
21
|
+
*
|
|
22
|
+
* @param pathObject Object with path components.
|
|
23
|
+
* @returns The formatted path.
|
|
24
|
+
*/
|
|
25
|
+
export function format(pathObject) {
|
|
26
|
+
return isWindows ? windowsFormat(pathObject) : posixFormat(pathObject);
|
|
27
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
// Copyright 2018-2025 the Deno authors. MIT license.
|
|
2
|
+
// This module is browser compatible.
|
|
3
|
+
import { isWindows } from "../../internal/1.0.12/os.js";
|
|
4
|
+
import { fromFileUrl as posixFromFileUrl } from "./posix/from_file_url.js";
|
|
5
|
+
import { fromFileUrl as windowsFromFileUrl } from "./windows/from_file_url.js";
|
|
6
|
+
/**
|
|
7
|
+
* Converts a file URL to a path string.
|
|
8
|
+
*
|
|
9
|
+
* @example Usage
|
|
10
|
+
* ```ts
|
|
11
|
+
* import { fromFileUrl } from "@std/path/from-file-url";
|
|
12
|
+
* import { assertEquals } from "@std/assert";
|
|
13
|
+
*
|
|
14
|
+
* if (Deno.build.os === "windows") {
|
|
15
|
+
* assertEquals(fromFileUrl("file:///home/foo"), "\\home\\foo");
|
|
16
|
+
* assertEquals(fromFileUrl("file:///C:/Users/foo"), "C:\\Users\\foo");
|
|
17
|
+
* assertEquals(fromFileUrl("file://localhost/home/foo"), "\\home\\foo");
|
|
18
|
+
* } else {
|
|
19
|
+
* assertEquals(fromFileUrl("file:///home/foo"), "/home/foo");
|
|
20
|
+
* }
|
|
21
|
+
* ```
|
|
22
|
+
*
|
|
23
|
+
* @param url The file URL to convert to a path.
|
|
24
|
+
* @returns The path string.
|
|
25
|
+
*/
|
|
26
|
+
export function fromFileUrl(url) {
|
|
27
|
+
return isWindows ? windowsFromFileUrl(url) : posixFromFileUrl(url);
|
|
28
|
+
}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
// Copyright 2018-2025 the Deno authors. MIT license.
|
|
2
|
+
// This module is browser compatible.
|
|
3
|
+
import { isWindows } from "../../internal/1.0.12/os.js";
|
|
4
|
+
import { globToRegExp as posixGlobToRegExp } from "./posix/glob_to_regexp.js";
|
|
5
|
+
import { globToRegExp as windowsGlobToRegExp, } from "./windows/glob_to_regexp.js";
|
|
6
|
+
/**
|
|
7
|
+
* Converts a glob string to a regular expression.
|
|
8
|
+
*
|
|
9
|
+
* Tries to match bash glob expansion as closely as possible.
|
|
10
|
+
*
|
|
11
|
+
* Basic glob syntax:
|
|
12
|
+
* - `*` - Matches everything without leaving the path segment.
|
|
13
|
+
* - `?` - Matches any single character.
|
|
14
|
+
* - `{foo,bar}` - Matches `foo` or `bar`.
|
|
15
|
+
* - `[abcd]` - Matches `a`, `b`, `c` or `d`.
|
|
16
|
+
* - `[a-d]` - Matches `a`, `b`, `c` or `d`.
|
|
17
|
+
* - `[!abcd]` - Matches any single character besides `a`, `b`, `c` or `d`.
|
|
18
|
+
* - `[[:<class>:]]` - Matches any character belonging to `<class>`.
|
|
19
|
+
* - `[[:alnum:]]` - Matches any digit or letter.
|
|
20
|
+
* - `[[:digit:]abc]` - Matches any digit, `a`, `b` or `c`.
|
|
21
|
+
* - See https://facelessuser.github.io/wcmatch/glob/#posix-character-classes
|
|
22
|
+
* for a complete list of supported character classes.
|
|
23
|
+
* - `\` - Escapes the next character for an `os` other than `"windows"`.
|
|
24
|
+
* - \` - Escapes the next character for `os` set to `"windows"`.
|
|
25
|
+
* - `/` - Path separator.
|
|
26
|
+
* - `\` - Additional path separator only for `os` set to `"windows"`.
|
|
27
|
+
*
|
|
28
|
+
* Extended syntax:
|
|
29
|
+
* - Requires `{ extended: true }`.
|
|
30
|
+
* - `?(foo|bar)` - Matches 0 or 1 instance of `{foo,bar}`.
|
|
31
|
+
* - `@(foo|bar)` - Matches 1 instance of `{foo,bar}`. They behave the same.
|
|
32
|
+
* - `*(foo|bar)` - Matches _n_ instances of `{foo,bar}`.
|
|
33
|
+
* - `+(foo|bar)` - Matches _n > 0_ instances of `{foo,bar}`.
|
|
34
|
+
* - `!(foo|bar)` - Matches anything other than `{foo,bar}`.
|
|
35
|
+
* - See https://www.linuxjournal.com/content/bash-extended-globbing.
|
|
36
|
+
*
|
|
37
|
+
* Globstar syntax:
|
|
38
|
+
* - Requires `{ globstar: true }`.
|
|
39
|
+
* - `**` - Matches any number of any path segments.
|
|
40
|
+
* - Must comprise its entire path segment in the provided glob.
|
|
41
|
+
* - See https://www.linuxjournal.com/content/globstar-new-bash-globbing-option.
|
|
42
|
+
*
|
|
43
|
+
* Note the following properties:
|
|
44
|
+
* - The generated `RegExp` is anchored at both start and end.
|
|
45
|
+
* - Repeating and trailing separators are tolerated. Trailing separators in the
|
|
46
|
+
* provided glob have no meaning and are discarded.
|
|
47
|
+
* - Absolute globs will only match absolute paths, etc.
|
|
48
|
+
* - Empty globs will match nothing.
|
|
49
|
+
* - Any special glob syntax must be contained to one path segment. For example,
|
|
50
|
+
* `?(foo|bar/baz)` is invalid. The separator will take precedence and the
|
|
51
|
+
* first segment ends with an unclosed group.
|
|
52
|
+
* - If a path segment ends with unclosed groups or a dangling escape prefix, a
|
|
53
|
+
* parse error has occurred. Every character for that segment is taken
|
|
54
|
+
* literally in this event.
|
|
55
|
+
*
|
|
56
|
+
* Limitations:
|
|
57
|
+
* - A negative group like `!(foo|bar)` will wrongly be converted to a negative
|
|
58
|
+
* look-ahead followed by a wildcard. This means that `!(foo).js` will wrongly
|
|
59
|
+
* fail to match `foobar.js`, even though `foobar` is not `foo`. Effectively,
|
|
60
|
+
* `!(foo|bar)` is treated like `!(@(foo|bar)*)`. This will work correctly if
|
|
61
|
+
* the group occurs not nested at the end of the segment.
|
|
62
|
+
*
|
|
63
|
+
* @example Usage
|
|
64
|
+
* ```ts
|
|
65
|
+
* import { globToRegExp } from "@std/path/glob-to-regexp";
|
|
66
|
+
* import { assertEquals } from "@std/assert";
|
|
67
|
+
*
|
|
68
|
+
* if (Deno.build.os === "windows") {
|
|
69
|
+
* assertEquals(globToRegExp("*.js"), /^[^\\/]*\.js(?:\\|\/)*$/);
|
|
70
|
+
* } else {
|
|
71
|
+
* assertEquals(globToRegExp("*.js"), /^[^/]*\.js\/*$/);
|
|
72
|
+
* }
|
|
73
|
+
* ```
|
|
74
|
+
*
|
|
75
|
+
* @param glob Glob string to convert.
|
|
76
|
+
* @param options Conversion options.
|
|
77
|
+
* @returns The regular expression equivalent to the glob.
|
|
78
|
+
*/
|
|
79
|
+
export function globToRegExp(glob, options = {}) {
|
|
80
|
+
return isWindows
|
|
81
|
+
? windowsGlobToRegExp(glob, options)
|
|
82
|
+
: posixGlobToRegExp(glob, options);
|
|
83
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
// Copyright 2018-2025 the Deno authors. MIT license.
|
|
2
|
+
// This module is browser compatible.
|
|
3
|
+
import { isWindows } from "../../internal/1.0.12/os.js";
|
|
4
|
+
import { isAbsolute as posixIsAbsolute } from "./posix/is_absolute.js";
|
|
5
|
+
import { isAbsolute as windowsIsAbsolute } from "./windows/is_absolute.js";
|
|
6
|
+
/**
|
|
7
|
+
* Verifies whether provided path is absolute.
|
|
8
|
+
*
|
|
9
|
+
* @example Usage
|
|
10
|
+
* ```ts
|
|
11
|
+
* import { isAbsolute } from "@std/path/is-absolute";
|
|
12
|
+
* import { assert, assertFalse } from "@std/assert";
|
|
13
|
+
*
|
|
14
|
+
* if (Deno.build.os === "windows") {
|
|
15
|
+
* assert(isAbsolute("C:\\home\\foo"));
|
|
16
|
+
* assertFalse(isAbsolute("home\\foo"));
|
|
17
|
+
* } else {
|
|
18
|
+
* assert(isAbsolute("/home/foo"));
|
|
19
|
+
* assertFalse(isAbsolute("home/foo"));
|
|
20
|
+
* }
|
|
21
|
+
* ```
|
|
22
|
+
*
|
|
23
|
+
* @param path Path to be verified as absolute.
|
|
24
|
+
* @returns `true` if path is absolute, `false` otherwise
|
|
25
|
+
*/
|
|
26
|
+
export function isAbsolute(path) {
|
|
27
|
+
return isWindows ? windowsIsAbsolute(path) : posixIsAbsolute(path);
|
|
28
|
+
}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
// Copyright 2018-2025 the Deno authors. MIT license.
|
|
2
|
+
// This module is browser compatible.
|
|
3
|
+
/**
|
|
4
|
+
* Test whether the given string is a glob.
|
|
5
|
+
*
|
|
6
|
+
* @example Usage
|
|
7
|
+
* ```ts
|
|
8
|
+
* import { isGlob } from "@std/path/is-glob";
|
|
9
|
+
* import { assert } from "@std/assert";
|
|
10
|
+
*
|
|
11
|
+
* assert(!isGlob("foo/bar/../baz"));
|
|
12
|
+
* assert(isGlob("foo/*ar/../baz"));
|
|
13
|
+
* ```
|
|
14
|
+
*
|
|
15
|
+
* @param str String to test.
|
|
16
|
+
* @returns `true` if the given string is a glob, otherwise `false`
|
|
17
|
+
*/
|
|
18
|
+
export function isGlob(str) {
|
|
19
|
+
const chars = { "{": "}", "(": ")", "[": "]" };
|
|
20
|
+
const regex = /\\(.)|(^!|\*|\?|[\].+)]\?|\[[^[\\\]]+\]|\{[^{\\}]+\}|\(\?[:!=][^\\)]+\)|\([^(|]+\|[^\\)]+\)|@\([^)]+\))/;
|
|
21
|
+
if (str === "") {
|
|
22
|
+
return false;
|
|
23
|
+
}
|
|
24
|
+
let match;
|
|
25
|
+
while ((match = regex.exec(str))) {
|
|
26
|
+
if (match[2])
|
|
27
|
+
return true;
|
|
28
|
+
let idx = match.index + match[0].length;
|
|
29
|
+
// if an open bracket/brace/paren is escaped,
|
|
30
|
+
// set the index to the next closing character
|
|
31
|
+
const open = match[1];
|
|
32
|
+
const close = open ? chars[open] : null;
|
|
33
|
+
if (open && close) {
|
|
34
|
+
const n = str.indexOf(close, idx);
|
|
35
|
+
if (n !== -1) {
|
|
36
|
+
idx = n + 1;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
str = str.slice(idx);
|
|
40
|
+
}
|
|
41
|
+
return false;
|
|
42
|
+
}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
// Copyright 2018-2025 the Deno authors. MIT license.
|
|
2
|
+
// This module is browser compatible.
|
|
3
|
+
import { isWindows } from "../../internal/1.0.12/os.js";
|
|
4
|
+
import { join as posixJoin } from "./posix/join.js";
|
|
5
|
+
import { join as windowsJoin } from "./windows/join.js";
|
|
6
|
+
/**
|
|
7
|
+
* Joins a sequence of paths, then normalizes the resulting path.
|
|
8
|
+
*
|
|
9
|
+
* @example Usage
|
|
10
|
+
* ```ts
|
|
11
|
+
* import { join } from "@std/path/join";
|
|
12
|
+
* import { assertEquals } from "@std/assert";
|
|
13
|
+
*
|
|
14
|
+
* if (Deno.build.os === "windows") {
|
|
15
|
+
* assertEquals(join("C:\\foo", "bar", "baz\\quux", "garply", ".."), "C:\\foo\\bar\\baz\\quux");
|
|
16
|
+
* assertEquals(join(new URL("file:///C:/foo"), "bar", "baz/asdf", "quux", ".."), "C:\\foo\\bar\\baz\\asdf");
|
|
17
|
+
* } else {
|
|
18
|
+
* assertEquals(join("/foo", "bar", "baz/quux", "garply", ".."), "/foo/bar/baz/quux");
|
|
19
|
+
* assertEquals(join(new URL("file:///foo"), "bar", "baz/asdf", "quux", ".."), "/foo/bar/baz/asdf");
|
|
20
|
+
* }
|
|
21
|
+
* ```
|
|
22
|
+
*
|
|
23
|
+
* @param path The path to join. This can be string or file URL.
|
|
24
|
+
* @param paths Paths to be joined and normalized.
|
|
25
|
+
* @returns The joined and normalized path.
|
|
26
|
+
*/
|
|
27
|
+
export function join(path, ...paths) {
|
|
28
|
+
return isWindows ? windowsJoin(path, ...paths) : posixJoin(path, ...paths);
|
|
29
|
+
}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
// Copyright 2018-2025 the Deno authors. MIT license.
|
|
2
|
+
// This module is browser compatible.
|
|
3
|
+
import { isWindows } from "../../internal/1.0.12/os.js";
|
|
4
|
+
import { joinGlobs as posixJoinGlobs } from "./posix/join_globs.js";
|
|
5
|
+
import { joinGlobs as windowsJoinGlobs } from "./windows/join_globs.js";
|
|
6
|
+
/**
|
|
7
|
+
* Joins a sequence of globs, then normalizes the resulting glob.
|
|
8
|
+
*
|
|
9
|
+
* Behaves like {@linkcode https://jsr.io/@std/path/doc/~/join | join()}, but
|
|
10
|
+
* doesn't collapse `**\/..` when `globstar` is true.
|
|
11
|
+
*
|
|
12
|
+
* @example Usage
|
|
13
|
+
* ```ts
|
|
14
|
+
* import { joinGlobs } from "@std/path/join-globs";
|
|
15
|
+
* import { assertEquals } from "@std/assert";
|
|
16
|
+
*
|
|
17
|
+
* if (Deno.build.os === "windows") {
|
|
18
|
+
* assertEquals(joinGlobs(["foo", "bar", "..", "baz"]), "foo\\baz");
|
|
19
|
+
* assertEquals(joinGlobs(["foo", "**", "bar", "..", "baz"], { globstar: true }), "foo\\**\\baz");
|
|
20
|
+
* } else {
|
|
21
|
+
* assertEquals(joinGlobs(["foo", "bar", "..", "baz"]), "foo/baz");
|
|
22
|
+
* assertEquals(joinGlobs(["foo", "**", "bar", "..", "baz"], { globstar: true }), "foo/**\/baz");
|
|
23
|
+
* }
|
|
24
|
+
* ```
|
|
25
|
+
*
|
|
26
|
+
* @param globs Globs to be joined and normalized.
|
|
27
|
+
* @param options Glob options.
|
|
28
|
+
* @returns The joined and normalized glob string.
|
|
29
|
+
*/
|
|
30
|
+
export function joinGlobs(globs, options = {}) {
|
|
31
|
+
return isWindows
|
|
32
|
+
? windowsJoinGlobs(globs, options)
|
|
33
|
+
: posixJoinGlobs(globs, options);
|
|
34
|
+
}
|