aboutsummaryrefslogtreecommitdiff
path: root/node_modules/get-package-type/sync.cjs
diff options
context:
space:
mode:
authorJoel Kronqvist <work.joelkronqvist@pm.me>2022-03-11 20:46:06 +0200
committerJoel Kronqvist <work.joelkronqvist@pm.me>2022-03-11 20:46:06 +0200
commit080c5819d87b933816d724a83f3bf4f1686770a7 (patch)
tree4a2ccc68b27edf7d4cbc586c932cc7542b655e19 /node_modules/get-package-type/sync.cjs
parent5ac7049a9d30733165cc212dee308163c2a14644 (diff)
parentd003b82235a9329f912522a2f70aa950dfce4998 (diff)
downloadLYLLRuoka-080c5819d87b933816d724a83f3bf4f1686770a7.tar.gz
LYLLRuoka-080c5819d87b933816d724a83f3bf4f1686770a7.zip
Merge branch 'master' of https://github.com/JoelHMikael/FoodJS
Updating remote changes
Diffstat (limited to 'node_modules/get-package-type/sync.cjs')
-rw-r--r--node_modules/get-package-type/sync.cjs42
1 files changed, 42 insertions, 0 deletions
diff --git a/node_modules/get-package-type/sync.cjs b/node_modules/get-package-type/sync.cjs
new file mode 100644
index 0000000..85090a6
--- /dev/null
+++ b/node_modules/get-package-type/sync.cjs
@@ -0,0 +1,42 @@
+'use strict';
+
+const path = require('path');
+const {readFileSync} = require('fs');
+
+const isNodeModules = require('./is-node-modules.cjs');
+const resultsCache = require('./cache.cjs');
+
+function getDirectoryTypeActual(directory) {
+ if (isNodeModules(directory)) {
+ return 'commonjs';
+ }
+
+ try {
+ return JSON.parse(readFileSync(path.resolve(directory, 'package.json'))).type || 'commonjs';
+ } catch (_) {
+ }
+
+ const parent = path.dirname(directory);
+ if (parent === directory) {
+ return 'commonjs';
+ }
+
+ return getDirectoryType(parent);
+}
+
+function getDirectoryType(directory) {
+ if (resultsCache.has(directory)) {
+ return resultsCache.get(directory);
+ }
+
+ const result = getDirectoryTypeActual(directory);
+ resultsCache.set(directory, result);
+
+ return result;
+}
+
+function getPackageTypeSync(filename) {
+ return getDirectoryType(path.resolve(path.dirname(filename)));
+}
+
+module.exports = getPackageTypeSync;