2016-11-28 03:18:36 -08:00
---
id: understanding-cli
title: Understanding the CLI
layout: docs
2017-07-28 08:17:22 -07:00
category: Contributing
2016-11-28 03:18:36 -08:00
permalink: docs/understanding-cli.html
2017-03-06 09:50:36 -08:00
banner: ejected
2017-07-28 08:17:22 -07:00
next: activityindicator
2017-06-07 11:40:26 -07:00
previous: testing
2016-11-28 03:18:36 -08:00
---
Though you may have installed the `react-native-cli` via npm as a separate module, it is a shell for accessing the CLI embedded
in the React Native of each project. Your commands and their effects are dependent on the version of the module of `react-native`
in context of the project. This guide will give a brief overview of the CLI in the module.
# The local CLI
React Native has a [`local-cli` ](https://github.com/facebook/react-native/tree/master/local-cli ) folder with a file named
[`cliEntry.js` ](https://github.com/facebook/react-native/blob/master/local-cli/cliEntry.js ). Here, the commands are read
from `commands.js` and added as possible CLI commands. _E.G._ the `react-native link` command, exists in the
[`react-native/local-cli/link` ](https://github.com/facebook/react-native/blob/master/local-cli/link/ ) folder, and is
required in `commands.js` , which will register it as a documented command to be exposed to the CLI.
# Command definitions
2017-01-06 08:21:26 -08:00
At the end of each command entry is an export. The export is an object with a function to perform, description of the command, and the command name. The object structure for the `link` command looks like so:
2016-11-28 03:18:36 -08:00
```js
module.exports = {
func: link,
description: 'links all native dependencies',
name: 'link [packageName]',
};
```
### Parameters
The command name identifies the parameters that a command would expect. When the command parameter is surrounded by greater-than, less-than symbols `< >` , this indicates that the parameter is expected. When a parameter is surrounded by brackets `[ ]` , this indicates that the parameter is optional.