|
1 | 1 | 'use strict'; |
| 2 | +const fs = require('fs'); |
2 | 3 | const path = require('path'); |
3 | | -const loadJsonFile = require('load-json-file'); |
4 | | -const pathType = require('path-type'); |
| 4 | +const parseJson = require('parse-json'); |
| 5 | +const promisify = require('util.promisify'); |
5 | 6 |
|
6 | | -module.exports = (fp, opts) => { |
7 | | - if (typeof fp !== 'string') { |
8 | | - opts = fp; |
9 | | - fp = '.'; |
10 | | - } |
| 7 | +const readFileAsync = promisify(fs.readFile); |
11 | 8 |
|
12 | | - opts = opts || {}; |
| 9 | +module.exports = options => { |
| 10 | + options = Object.assign({ |
| 11 | + cwd: process.cwd(), |
| 12 | + normalize: true |
| 13 | + }, options); |
13 | 14 |
|
14 | | - return pathType.dir(fp) |
15 | | - .then(isDir => { |
16 | | - if (isDir) { |
17 | | - fp = path.join(fp, 'package.json'); |
18 | | - } |
| 15 | + const filePath = path.resolve(options.cwd, 'package.json'); |
19 | 16 |
|
20 | | - return loadJsonFile(fp); |
21 | | - }) |
22 | | - .then(x => { |
23 | | - if (opts.normalize !== false) { |
24 | | - require('normalize-package-data')(x); |
25 | | - } |
| 17 | + return readFileAsync(filePath, 'utf8').then(file => { |
| 18 | + const json = parseJson(file); |
26 | 19 |
|
27 | | - return x; |
28 | | - }); |
29 | | -}; |
| 20 | + if (options.normalize) { |
| 21 | + require('normalize-package-data')(json); |
| 22 | + } |
30 | 23 |
|
31 | | -module.exports.sync = (fp, opts) => { |
32 | | - if (typeof fp !== 'string') { |
33 | | - opts = fp; |
34 | | - fp = '.'; |
35 | | - } |
| 24 | + return json; |
| 25 | + }); |
| 26 | +}; |
36 | 27 |
|
37 | | - opts = opts || {}; |
38 | | - fp = pathType.dirSync(fp) ? path.join(fp, 'package.json') : fp; |
| 28 | +module.exports.sync = options => { |
| 29 | + options = Object.assign({ |
| 30 | + cwd: process.cwd(), |
| 31 | + normalize: true |
| 32 | + }, options); |
39 | 33 |
|
40 | | - const x = loadJsonFile.sync(fp); |
| 34 | + const filePath = path.resolve(options.cwd, 'package.json'); |
| 35 | + const json = parseJson(fs.readFileSync(filePath, 'utf8')); |
41 | 36 |
|
42 | | - if (opts.normalize !== false) { |
43 | | - require('normalize-package-data')(x); |
| 37 | + if (options.normalize) { |
| 38 | + require('normalize-package-data')(json); |
44 | 39 | } |
45 | 40 |
|
46 | | - return x; |
| 41 | + return json; |
47 | 42 | }; |
0 commit comments