To become highly productive in working on Zulip Mobile, you'll want to set up an editor, or IDE, with good support for navigation and type information. This makes a big difference in productivity, and especially so when working in a codebase that's new to you.
Currently there's one editor we recommend for normal work in our codebase: Visual Studio Code.
Visual Studio Code is an open-source IDE which supports our codebase well, with good support for features like navigating to a definition or showing type information.
To use it, install VS Code.
Install the following extensions, which support important aspects of our codebase. Each extension page has install instructions at the top.
For the extensions to work properly, make sure that VS Code has recognized
our settings file
in the zulip-mobile repository. Usually, this should happen automatically
when you open the zulip-mobile
folder in VS Code. You can verify that the
settings were recognized by opening your Workspace Settings with
Ctrl+Shift+P
-> Open Workspace Settings
. If the editor on the right-hand
side starts with the comment
// Workspace Settings for the zulip-mobile repo.
you're all set - VS Code has recognized your workspace settings. If not,
make sure that you opened VS Code as a folder. Do this by pressing
Ctrl+K Ctrl+O
and navigating to your local zulip-mobile
clone.
Take a look through some of VS Code's docs. In particular:
-
Be sure to look at the Code Navigation doc, and try out Go to Definition (F12), Quick Open (Ctrl+P), and Open Symbol by Name (Ctrl+T). These can make it much faster to move around our codebase to read and understand it.
-
Get the keyboard shortcuts PDF reference for your platform, and print it out. It's a one-page PDF which is extremely helpful to refer to.
-
Open any JS file in our codebase, and try messing up some formatting by adding random whitespace -- then hit Ctrl+S (or Cmd+S) to save. You should see the formatting get magically fixed! Our workspace settings enable this feature, and configure it to use our standard formatting rules.
When you save a file after installing the extensions above, the file should be automatically formatted to stick to our code-formatting style.
If instead it gets reformatted with lots of changes, for example like this:
export {
default as Arc
}
from './Arc';
this might be caused by additional extensions you have installed.
To fix the problem, view your extensions. On each extension you have enabled that isn't in our list above, select "Disable (Workspace)" to disable it for your Zulip Mobile workspace (or "Disable" or "Uninstall", if you no longer want it in general.)
Once you have things working with purely our standard list of extensions, you can re-enable other extensions one at a time to identify which one caused the problem.
Android Studio is the IDE supported upstream by the Android platform in
general. Its support for Java and for Android-specific quirks is excellent,
while VS Code's is not very good. When working in the Android-specific part
of our codebase (android/
), we therefore recommend using Android Studio.
Using other editors isn't generally recommended. Here's some miscellaneous information if you do.
- We format our code using
prettier
. Runtools/fmt
to do this manually. (If using Atom, theprettier-atom
plugin helps.)