mirror of
https://github.com/status-im/metro.git
synced 2025-01-20 16:09:21 +00:00
[react-packager] Allow json files as modules
This commit is contained in:
parent
201d65dead
commit
f91f7084ec
@ -45,6 +45,8 @@ function ModuleDescriptor(fields) {
|
||||
|
||||
this.altId = fields.altId;
|
||||
|
||||
this.isJSON = fields.isJSON;
|
||||
|
||||
this._fields = fields;
|
||||
}
|
||||
|
||||
|
@ -101,6 +101,46 @@ describe('DependencyGraph', function() {
|
||||
});
|
||||
});
|
||||
|
||||
pit('should get json dependencies', function() {
|
||||
var root = '/root';
|
||||
fs.__setMockFilesystem({
|
||||
'root': {
|
||||
'package.json': JSON.stringify({
|
||||
name: 'package'
|
||||
}),
|
||||
'index.js': [
|
||||
'/**',
|
||||
' * @providesModule index',
|
||||
' */',
|
||||
'require("./a.json")'
|
||||
].join('\n'),
|
||||
'a.json': JSON.stringify({}),
|
||||
}
|
||||
});
|
||||
|
||||
var dgraph = new DependencyGraph({
|
||||
roots: [root],
|
||||
fileWatcher: fileWatcher
|
||||
});
|
||||
return dgraph.load().then(function() {
|
||||
expect(dgraph.getOrderedDependencies('/root/index.js'))
|
||||
.toEqual([
|
||||
{
|
||||
id: 'index',
|
||||
altId: 'package/index',
|
||||
path: '/root/index.js',
|
||||
dependencies: ['./a.json']
|
||||
},
|
||||
{
|
||||
id: 'package/a.json',
|
||||
isJSON: true,
|
||||
path: '/root/a.json',
|
||||
dependencies: []
|
||||
},
|
||||
]);
|
||||
});
|
||||
});
|
||||
|
||||
pit('should get dependencies with deprecated assets', function() {
|
||||
var root = '/root';
|
||||
fs.__setMockFilesystem({
|
||||
|
@ -66,7 +66,7 @@ function DependecyGraph(options) {
|
||||
this._debugUpdateEvents = [];
|
||||
|
||||
this._moduleExtPattern = new RegExp(
|
||||
'\.(' + ['js'].concat(this._assetExts).join('|') + ')$'
|
||||
'\.(' + ['js', 'json'].concat(this._assetExts).join('|') + ')$'
|
||||
);
|
||||
|
||||
// Kick off the search process to precompute the dependency graph.
|
||||
@ -259,7 +259,7 @@ DependecyGraph.prototype.resolveDependency = function(
|
||||
}
|
||||
|
||||
// JS modules can be required without extensios.
|
||||
if (!this._isFileAsset(modulePath)) {
|
||||
if (!this._isFileAsset(modulePath) && !modulePath.match(/\.json$/)) {
|
||||
modulePath = withExtJs(modulePath);
|
||||
}
|
||||
|
||||
@ -432,6 +432,15 @@ DependecyGraph.prototype._processModule = function(modulePath) {
|
||||
return Promise.resolve(module);
|
||||
}
|
||||
|
||||
if (extname(modulePath) === 'json') {
|
||||
moduleData.id = this._lookupName(modulePath);
|
||||
moduleData.isJSON = true;
|
||||
moduleData.dependencies = [];
|
||||
module = new ModuleDescriptor(moduleData);
|
||||
this._updateGraphWithModule(module);
|
||||
return Promise.resolve(module);
|
||||
}
|
||||
|
||||
var self = this;
|
||||
return readFile(modulePath, 'utf8')
|
||||
.then(function(content) {
|
||||
|
@ -43,6 +43,10 @@ describe('Packager', function() {
|
||||
};
|
||||
});
|
||||
|
||||
require('fs').readFile.mockImpl(function(file, callback) {
|
||||
callback(null, '{"json":true}');
|
||||
});
|
||||
|
||||
var packager = new Packager({projectRoots: ['/root']});
|
||||
var modules = [
|
||||
{id: 'foo', path: '/root/foo.js', dependencies: []},
|
||||
@ -60,7 +64,13 @@ describe('Packager', function() {
|
||||
isAsset: true,
|
||||
resolution: 2,
|
||||
dependencies: []
|
||||
}
|
||||
},
|
||||
{
|
||||
id: 'package/file.json',
|
||||
path: '/root/file.json',
|
||||
isJSON: true,
|
||||
dependencies: [],
|
||||
},
|
||||
];
|
||||
|
||||
getDependencies.mockImpl(function() {
|
||||
@ -137,6 +147,12 @@ describe('Packager', function() {
|
||||
'/root/img/new_image.png'
|
||||
]);
|
||||
|
||||
expect(p.addModule.mock.calls[4]).toEqual([
|
||||
'lol module.exports = {"json":true}; lol',
|
||||
'module.exports = {"json":true};',
|
||||
'/root/file.json'
|
||||
]);
|
||||
|
||||
expect(p.finalize.mock.calls[0]).toEqual([
|
||||
{runMainModule: true}
|
||||
]);
|
||||
|
15
react-packager/src/Packager/index.js
vendored
15
react-packager/src/Packager/index.js
vendored
@ -21,6 +21,7 @@ var declareOpts = require('../lib/declareOpts');
|
||||
var imageSize = require('image-size');
|
||||
|
||||
var sizeOf = Promise.promisify(imageSize);
|
||||
var readFile = Promise.promisify(fs.readFile);
|
||||
|
||||
var validateOpts = declareOpts({
|
||||
projectRoots: {
|
||||
@ -147,6 +148,8 @@ Packager.prototype._transformModule = function(ppackage, module) {
|
||||
transform = this.generateAssetModule_DEPRECATED(ppackage, module);
|
||||
} else if (module.isAsset) {
|
||||
transform = this.generateAssetModule(ppackage, module);
|
||||
} else if (module.isJSON) {
|
||||
transform = generateJSONModule(module);
|
||||
} else {
|
||||
transform = this._transformer.loadFileAndTransform(
|
||||
path.resolve(module.path)
|
||||
@ -206,6 +209,18 @@ Packager.prototype.generateAssetModule = function(ppackage, module) {
|
||||
|
||||
var code = 'module.exports = ' + JSON.stringify(img) + ';';
|
||||
|
||||
return {
|
||||
code: code,
|
||||
sourceCode: code,
|
||||
sourcePath: module.path,
|
||||
};
|
||||
});
|
||||
};
|
||||
|
||||
function generateJSONModule(module) {
|
||||
return readFile(module.path).then(function(data) {
|
||||
var code = 'module.exports = ' + data.toString('utf8') + ';';
|
||||
|
||||
return {
|
||||
code: code,
|
||||
sourceCode: code,
|
||||
|
2
react-packager/src/Server/index.js
vendored
2
react-packager/src/Server/index.js
vendored
@ -80,7 +80,7 @@ function Server(options) {
|
||||
dir: dir,
|
||||
globs: [
|
||||
'**/*.js',
|
||||
'**/package.json',
|
||||
'**/*.json',
|
||||
].concat(assetGlobs),
|
||||
};
|
||||
});
|
||||
|
Loading…
x
Reference in New Issue
Block a user