mirror of
https://github.com/status-im/react-native.git
synced 2025-01-10 09:35:48 +00:00
30e89b49f1
Summary: This is step one on merging the `rnpm` config with the `cli config`. The plan is to remove two sources of truth (rnpm package.json config and rn-cli Javascript config) Rationale: As of now, we have `rnpm` config, that used to live in the `local-cli/core/config/index.js` and the `rn-cli` config, living in `default.config.js` and `utils/Config.js`. This PR moves all the things into one file, called `local-cli/core', simplifies things, enhances types (Config now has better types, added missing properties and fixed descriptions). One notable addition is that users can now opt-in to override the commands that are loaded at the package level. Previously it was only possible to add a command by writing a plugin. Now, you can just tweak the `rn-cli.config.js`. This is one of the several improvements I have on my roadmap, with better documentation for the CLI as well. Closes https://github.com/facebook/react-native/pull/11564 Differential Revision: D4360095 fbshipit-source-id: feaec7c88df63e51cef1f9620c7eedeb738d3d00
61 lines
1.4 KiB
JavaScript
61 lines
1.4 KiB
JavaScript
/**
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
* All rights reserved.
|
|
*
|
|
* This source code is licensed under the BSD-style license found in the
|
|
* LICENSE file in the root directory of this source tree. An additional grant
|
|
* of patent rights can be found in the PATENTS file in the same directory.
|
|
*/
|
|
'use strict';
|
|
|
|
const glob = require('glob');
|
|
const path = require('path');
|
|
|
|
/**
|
|
* Glob pattern to look for solution file
|
|
*/
|
|
const GLOB_PATTERN = '**/*.sln';
|
|
|
|
/**
|
|
* Regexp matching all test projects
|
|
*/
|
|
const TEST_PROJECTS = /test|example|sample/i;
|
|
|
|
/**
|
|
* Base windows folder
|
|
*/
|
|
const WINDOWS_BASE = 'windows';
|
|
|
|
/**
|
|
* These folders will be excluded from search to speed it up
|
|
*/
|
|
const GLOB_EXCLUDE_PATTERN = ['**/@(node_modules)/**'];
|
|
|
|
/**
|
|
* Finds windows project by looking for all .sln files
|
|
* in given folder.
|
|
*
|
|
* Returns first match if files are found or null
|
|
*
|
|
* Note: `./windows/*.sln` are returned regardless of the name
|
|
*/
|
|
module.exports = function findSolution(folder) {
|
|
const projects = glob
|
|
.sync(GLOB_PATTERN, {
|
|
cwd: folder,
|
|
ignore: GLOB_EXCLUDE_PATTERN,
|
|
})
|
|
.filter(project => {
|
|
return path.dirname(project) === WINDOWS_BASE || !TEST_PROJECTS.test(project);
|
|
})
|
|
.sort((projectA, projectB) => {
|
|
return path.dirname(projectA) === WINDOWS_BASE ? -1 : 1;
|
|
});
|
|
|
|
if (projects.length === 0) {
|
|
return null;
|
|
}
|
|
|
|
return projects[0];
|
|
};
|