This file contains tips to help you take (and understand) your first steps in the world of Theia development. Are you in a hurry? See the tl;dr.
Theia is a framework to build IDEs, so you can't really "run" Theia itself. However, you can run the example applications included in its repository. One is a browser-based IDE and the other is the electron-based equivalent.
The following instructions are for Linux and macOS.
For Windows instructions click here.
So far it has been confirmed that there are some problems and errors using nodejs 8.0+ with Theia. As of now, nodejs 7.10.0 is confirmed to be working well and is the currently recommended versions.
nvm is recommended to easily switch between node versions.
git clone https://github.com/theia-ide/theia
The directory containing the Theia repository will now be referred to as
$THEIA
, so if you want to copy-paste the examples, you can set the THEIA
variable in your shell:
THEIA=$PWD/theia
You can download dependencies and build it using:
cd $THEIA
yarn
This command does a few things:
- downloads node package dependencies
- generate package.json for node packages
- link core, extensions and examples packages
- build core, extensions and examples packages
We can start the application from the examples/browser directory with:
yarn run start
This command starts the backend application, a small web server and a browser tab with the frontend.
If you rebuild native node packages for electron then rollback these changes before starting the browser example by running from the root directory:
yarn run rebuild:browser
From the root directory run:
yarn run rebuild:electron
This command rebuilds native node packages against the version of node used by electron.
It can also be started from the examples/electron directory with:
yarn run start
In the root directory run:
yarn run build
To rebuild each time a change is detected run:
yarn run watch
To rebuild each time a change is detected in frontend or backend you can run:
yarn run watch
To debug an example using VSCode:
- Start the debug tab and run the
Launch Backend
configuration.
- Start the frontend using
yarn run start:frontend
- In a browser: open http://localhost:8080/ and use the dev tools for debugging
- In VS Code: start the debug tab and run the
Launch Frontend
configuration.
- create a symlink to theia directory
ln -s theia theia-frontend
- Open one vscode in theia directory.
- Open another vscode in theia-frontend directory.
- In one vscode window: start the debug tab and run the
Launch Backend
configuration. - In the other vscode window: start the debug tab and run the
Launch Frontend
configuration.
This one you can build as usual with yarn run build
and then use Chrome's
dev tools to debug.
There's an issue debugging with vscode it seems electron runs at 100% and debugging doesn't work.
Note that we should be able to debug both frontend and backend in one window but I've this this issue when trying that. tl;dr Some breakpoints don't hit.
See the testing documentation.
To build and run the browser example:
git clone https://github.com/theia-ide/theia \
&& cd theia \
&& yarn --unsafe-perm \
&& cd examples/browser \
&& yarn run start
To build and run the electron example:
git clone https://github.com/theia-ide/theia \
&& cd theia \
&& yarn --unsafe-perm \
&& yarn run rebuild:electron \
&& cd examples/electron \
&& yarn run start
yarn run test
By default this will generate the code coverage for the tests in a HTML format, which can be easily viewed with your browser (chrome/firefox/edge/safari etc.) by opening packages/<package name>/coverage/index.html
Run cmd.exe as an administrator and install choco
by copy-pasting the command to your console:
@"%SystemRoot%\System32\WindowsPowerShell\v1.0\powershell.exe" -NoProfile -ExecutionPolicy Bypass -Command "iex ((New-Object System.Net.WebClient).DownloadString('https://chocolatey.org/install.ps1'))" && SET "PATH=%PATH%;%ALLUSERSPROFILE%\chocolatey\bin"
Install yarn
via choco
. The yarn
installation ensures that you will have Node.js and npm too:
choco install yarn
Install git
via choco
.
choco install git
Install Windows-Build-Tools. Run PowerShell as an administrator and copy-paste the below command:
npm --add-python-to-path install --global --production windows-build-tools
Clone, build and run Theia. Using Git Bash as administrator:
git clone https://github.com/theia-ide/theia.git && cd theia && yarn && cd examples/browser && yarn run start
The start command will start a watcher on many files in the theia directory. To avoid ENOSPC errors, increase your default inotify watches.
It can be done like so:
echo fs.inotify.max_user_watches=524288 | sudo tee -a /etc/sysctl.conf && sudo sysctl -p
Theia uses native modules and also requires Python 2.x to be installed on the system when building the application.
- One can get all the all-in-one packages by running
npm install --global windows-build-tools
script.
If you are facing with EPERM: operation not permitted
or permission denied
errors while building, testing or running the application then;
- You don't have write access to the installation directory.
- Try to run your command line (
PowerShell
,GitBash
,Cygwin
or whatever you are using) as an administrator. - The permissions in the NPM cache might get corrupted. Please try to run
npm cache clean
to fix them. - If you experience issues such as
Error: EBUSY: resource busy or locked, rename
, try to disable (or uninstall) your anti-malware software. See here. - Still having issues on Windows? File a bug. We are working on Linux or OS X operating systems. Hence we are more than happy to receive any Windows related feedbacks, bug reports.