2011-12-21 21:07:39 +01:00
|
|
|
@title Diffusion User Guide: Symbol Indexes
|
|
|
|
@group userguide
|
|
|
|
|
|
|
|
Guide to configuring and using the symbol index.
|
|
|
|
|
|
|
|
= Overview =
|
|
|
|
|
|
|
|
Phabricator can maintain a symbol index, which keeps track of where classes
|
|
|
|
and functions are defined in the codebase. Once you set up indexing, you can
|
|
|
|
use the index to do things like:
|
|
|
|
|
2015-07-07 15:22:33 +02:00
|
|
|
- jump to symbol definitions from Differential code reviews and Diffusion
|
|
|
|
code browsing by ctrl-clicking (cmd-click on Mac) symbols
|
|
|
|
- search for symbols from the quick-search
|
2011-12-21 21:07:39 +01:00
|
|
|
- let the IRC bot answer questions like "Where is SomeClass?"
|
|
|
|
|
2015-07-07 15:22:33 +02:00
|
|
|
NOTE: Because this feature depends on the syntax highlighter, it will work
|
|
|
|
better for some languages than others. It currently works fairly well for PHP,
|
|
|
|
but your mileage may vary for other languages.
|
2011-12-21 21:07:39 +01:00
|
|
|
|
|
|
|
= Populating the Index =
|
|
|
|
|
|
|
|
To populate the index, you need to write a script which identifies symbols in
|
|
|
|
your codebase and set up a cronjob which pipes its output to:
|
|
|
|
|
2015-05-05 13:11:30 +02:00
|
|
|
./scripts/symbols/import_repository_symbols.php
|
2011-12-21 21:07:39 +01:00
|
|
|
|
|
|
|
Phabricator includes a script which can identify symbols in PHP projects:
|
|
|
|
|
|
|
|
./scripts/symbols/generate_php_symbols.php
|
|
|
|
|
2012-03-25 18:49:52 +02:00
|
|
|
Phabricator also includes a script which can identify symbols in any
|
|
|
|
programming language that has classes and/or functions, and is supported by
|
|
|
|
Exuberant Ctags (http://ctags.sourceforge.net):
|
|
|
|
|
|
|
|
./scripts/symbols/generate_ctags_symbols.php
|
|
|
|
|
2011-12-21 21:07:39 +01:00
|
|
|
If you want to identify symbols from another language, you need to write a
|
2015-05-31 02:07:45 +02:00
|
|
|
script which can export them (for example, maybe by parsing a `ctags` file).
|
2011-12-21 21:07:39 +01:00
|
|
|
|
|
|
|
The output format of the script should be one symbol per line:
|
|
|
|
|
2012-08-07 18:29:34 +02:00
|
|
|
<context> <name> <type> <lang> <line> <path>
|
2011-12-21 21:07:39 +01:00
|
|
|
|
|
|
|
For example:
|
|
|
|
|
2012-08-07 18:29:34 +02:00
|
|
|
ExampleClass exampleMethod function php 13 /src/classes/ExampleClass.php
|
|
|
|
|
|
|
|
Context is, broadly speaking, the scope or namespace where the symbol is
|
|
|
|
defined. For object-oriented languages, this is probably a class name. The
|
|
|
|
symbols with that context are class constants, methods, properties, nested
|
|
|
|
classes, etc. When printing symbols without a context (those that are defined
|
2015-05-31 02:07:45 +02:00
|
|
|
globally, for instance), the `<context>` field should be empty (that is, the
|
2012-08-07 18:29:34 +02:00
|
|
|
line should start with a space).
|
2011-12-21 21:07:39 +01:00
|
|
|
|
|
|
|
Your script should enumerate all the symbols in your project, and provide paths
|
2012-08-07 18:29:34 +02:00
|
|
|
from the project root (where ".arcconfig" is) beginning with a "/".
|
2011-12-21 21:07:39 +01:00
|
|
|
|
2015-05-31 02:07:45 +02:00
|
|
|
You can look at `generate_php_symbols.php` for an example of how you might
|
2011-12-21 21:07:39 +01:00
|
|
|
write such a script, and run this command to see its output:
|
|
|
|
|
|
|
|
$ cd phabricator/
|
|
|
|
$ find . -type f -name '*.php' | ./scripts/symbols/generate_php_symbols.php
|
|
|
|
|
|
|
|
To actually build the symbol index, pipe this data to the
|
2015-05-05 13:11:30 +02:00
|
|
|
`import_repository_symbols.php` script, providing the repository callsign:
|
2011-12-21 21:07:39 +01:00
|
|
|
|
2015-08-29 00:05:05 +02:00
|
|
|
$ ./scripts/symbols/import_repository_symbols.php REPO < symbols_data
|
2011-12-21 21:07:39 +01:00
|
|
|
|
|
|
|
Then just set up a cronjob to run that however often you like.
|
|
|
|
|
|
|
|
You can test that the import worked by querying for symbols using the Conduit
|
2015-05-31 02:07:45 +02:00
|
|
|
method `diffusion.findsymbols`. Some features (like that method, and the
|
2011-12-21 21:07:39 +01:00
|
|
|
IRC bot integration) will start working immediately. Others will require more
|
|
|
|
configuration.
|
|
|
|
|
2015-05-05 13:11:30 +02:00
|
|
|
= Advanced Configuration =
|
2011-12-21 21:07:39 +01:00
|
|
|
|
2015-05-05 13:11:30 +02:00
|
|
|
You can configure some more options by going to {nav Diffusion > (Select
|
|
|
|
repository) > Edit Repository > Edit Symbols}, and filling out these fields:
|
2011-12-21 21:07:39 +01:00
|
|
|
|
|
|
|
- **Indexed Languages**: Fill in all the languages you've built indexes for.
|
2015-05-05 13:11:30 +02:00
|
|
|
You can leave this blank for "All languages".
|
|
|
|
- **Uses Symbols From**: If this project depends on other repositories, add
|
|
|
|
the other repositories which symbols should be looked for here. For example,
|
2011-12-21 21:07:39 +01:00
|
|
|
Phabricator lists "Arcanist" and "libphutil" because it uses classes and
|
2015-05-05 13:11:30 +02:00
|
|
|
functions from these repositories.
|
2011-12-21 21:07:39 +01:00
|
|
|
|
2015-07-07 15:22:33 +02:00
|
|
|
== External Symbols ==
|
|
|
|
|
2015-09-30 16:44:54 +02:00
|
|
|
By @{article@phabcontrib:Adding New Classes}, you can teach Phabricator
|
2015-07-07 15:22:33 +02:00
|
|
|
about symbols from the outside world.
|
|
|
|
Extend @{class:DiffusionExternalSymbolsSource}; Once loaded, your new
|
|
|
|
implementation will be used any time a symbol is queried.
|
|
|
|
|
|
|
|
See @{class:DiffusionPhpExternalSymbolsSource} and
|
|
|
|
@{class:DiffusionPythonExternalSymbolsSource} for example implementations.
|