2016-06-23 07:50:28 -07:00
|
|
|
/**
|
|
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
|
|
*
|
2018-02-16 18:24:55 -08:00
|
|
|
* This source code is licensed under the MIT license found in the
|
|
|
|
* LICENSE file in the root directory of this source tree.
|
2018-05-11 12:43:49 -07:00
|
|
|
*
|
|
|
|
* @format
|
2016-06-23 07:50:28 -07:00
|
|
|
*/
|
2018-05-11 12:43:49 -07:00
|
|
|
|
2016-06-23 07:50:28 -07:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
const chalk = require('chalk');
|
|
|
|
const child_process = require('child_process');
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Starts adb logcat
|
|
|
|
*/
|
|
|
|
function logAndroid() {
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
_logAndroid(resolve, reject);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2016-07-30 08:59:16 -07:00
|
|
|
function _logAndroid() {
|
2016-06-23 07:50:28 -07:00
|
|
|
try {
|
|
|
|
const adbPath = process.env.ANDROID_HOME
|
|
|
|
? process.env.ANDROID_HOME + '/platform-tools/adb'
|
|
|
|
: 'adb';
|
|
|
|
|
|
|
|
const adbArgs = ['logcat', '*:S', 'ReactNative:V', 'ReactNativeJS:V'];
|
|
|
|
|
2018-05-11 12:43:49 -07:00
|
|
|
console.log(
|
|
|
|
chalk.bold(`Starting the logger (${adbPath} ${adbArgs.join(' ')})...`),
|
|
|
|
);
|
2016-06-23 07:50:28 -07:00
|
|
|
|
|
|
|
const log = child_process.spawnSync(adbPath, adbArgs, {stdio: 'inherit'});
|
|
|
|
|
|
|
|
if (log.error !== null) {
|
|
|
|
throw log.error;
|
|
|
|
}
|
|
|
|
} catch (e) {
|
2018-05-11 12:43:49 -07:00
|
|
|
console.log(
|
|
|
|
chalk.red('adb invocation failed. Do you have adb in your PATH?'),
|
|
|
|
);
|
2016-07-30 08:59:16 -07:00
|
|
|
return Promise.reject();
|
2016-06-23 07:50:28 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-07-30 08:59:16 -07:00
|
|
|
module.exports = {
|
|
|
|
name: 'log-android',
|
|
|
|
description: 'starts adb logcat',
|
|
|
|
func: logAndroid,
|
|
|
|
};
|