Skip to content

Commit

Permalink
Add 'j' to debug key handler (facebook#39256)
Browse files Browse the repository at this point in the history
Summary:
Pull Request resolved: facebook#39256

## Context

RFC: Decoupling Flipper from React Native core: react-native-community/discussions-and-proposals#641

## Changes

- Adds `j` key handler to open JS debugger (mirroring Expo CLI).
- Updates `isDevServerRunning` to consider server scheme and host.
- Reorders key prompts.

Changelog:
[General][Changed] Add 'j' to debug key trigger from CLI

Reviewed By: motiz88

Differential Revision: D48873335

fbshipit-source-id: 111018ac51bc05f571d4ef40bf1a3bb9871e0b84
  • Loading branch information
huntie authored and facebook-github-bot committed Sep 4, 2023
1 parent 87e449c commit 0d9330d
Show file tree
Hide file tree
Showing 4 changed files with 30 additions and 7 deletions.
1 change: 1 addition & 0 deletions packages/community-cli-plugin/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@
"metro": "0.78.0",
"metro-config": "0.78.0",
"metro-core": "0.78.0",
"node-fetch": "^2.2.0",
"readline": "^1.3.0"
},
"devDependencies": {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,19 +17,25 @@ import {
} from '@react-native-community/cli-tools';
import chalk from 'chalk';
import execa from 'execa';
import fetch from 'node-fetch';
import readline from 'readline';
import {KeyPressHandler} from '../../utils/KeyPressHandler';

const CTRL_C = '\u0003';
const CTRL_Z = '\u0026';

export default function attachKeyHandlers(
export default function attachKeyHandlers({
cliConfig,
devServerUrl,
messageSocket,
}: {
cliConfig: Config,
devServerUrl: string,
messageSocket: $ReadOnly<{
broadcast: (type: string, params?: Record<string, mixed> | null) => void,
...
}>,
) {
}) {
if (process.stdin.isTTY !== true) {
logger.debug('Interactive mode is not supported in this environment');
return;
Expand Down Expand Up @@ -77,6 +83,9 @@ export default function attachKeyHandlers(
execaOptions,
).stdout?.pipe(process.stdout);
break;
case 'j':
await fetch(devServerUrl + '/open-debugger', {method: 'POST'});
break;
case CTRL_Z:
process.emit('SIGTSTP', 'SIGTSTP');
break;
Expand All @@ -93,10 +102,11 @@ export default function attachKeyHandlers(
logger.log(
'\n' +
[
`${chalk.bold('r')} - reload app`,
`${chalk.bold('d')} - open Dev Menu`,
`${chalk.bold('i')} - run on iOS`,
`${chalk.bold('a')} - run on Android`,
`${chalk.bold('d')} - open Dev Menu`,
`${chalk.bold('j')} - open debugger`,
`${chalk.bold('r')} - reload app`,
].join('\n'),
);
}
15 changes: 13 additions & 2 deletions packages/community-cli-plugin/src/commands/start/runServer.js
Original file line number Diff line number Diff line change
Expand Up @@ -68,10 +68,17 @@ async function runServer(
server: {port},
watchFolders,
} = metroConfig;
const scheme = args.https === true ? 'https' : 'http';
const devServerUrl = `${scheme}://${host}:${port}`;

logger.info(`Welcome to React Native v${ctx.reactNativeVersion}`);

const serverStatus = await isDevServerRunning(host, port, projectRoot);
const serverStatus = await isDevServerRunning(
scheme,
host,
port,
projectRoot,
);

if (serverStatus === 'matched_server_running') {
logger.info(
Expand Down Expand Up @@ -124,7 +131,11 @@ async function runServer(
}
if (args.interactive && event.type === 'dep_graph_loaded') {
logger.info('Dev server ready');
attachKeyHandlers(ctx, messageSocketEndpoint);
attachKeyHandlers({
cliConfig: ctx,
devServerUrl,
messageSocket: messageSocketEndpoint,
});
}
},
};
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ import fetch from 'node-fetch';
* - `unknown`: An error was encountered; attempt server creation anyway.
*/
export default async function isDevServerRunning(
scheme: string,
host: string,
port: number,
projectRoot: string,
Expand All @@ -34,7 +35,7 @@ export default async function isDevServerRunning(
return 'not_running';
}

const statusResponse = await fetch(`http://localhost:${port}/status`);
const statusResponse = await fetch(`${scheme}://${host}:${port}/status`);
const body = await statusResponse.text();

return body === 'packager-status:running' &&
Expand Down

0 comments on commit 0d9330d

Please sign in to comment.