This repository follows a simplified Forking Workflow (an adaptation from the Gitflow Workflow) to manage changes and branches. Detailed explanation could be found here. In practice, just follow these steps:
- create your own fork of the repository
- branch off from the latest
master
branch - finish changes in the feature branch
- create pull request to the
master
branch and go through the review process
Done!
For team-managed projects (like this one), even if you have the access to make changes directly through git push
, it is still recommended to makes changes through pull requests so that all changes could be reviewed, verified, and clearly recorded as commits. To do that, follow the forking workflow used in most open-source projects.
After creating a fork of a repository, make sure to configure a remote first so the fork can sync up with the remote repository. For example, when working on a fork from this repository, do this first:
git add upstream https://github.com/ms-iot/vscode-ros
Note: the remote name does not need to be upstream
, we are just using upstream
as an example
Forks do not automatically sync with the original repository, to keep forks up-to-date, here are a few ways to accomplish that:
-
fetch + merge
as described in GitHub's syncing a fork guidegit fetch -p upstream git checkout <branch> git merge upstream/<branch>
-
pull upstream
(git pull
is a wrapper forfetch + merge
)git checkout <branch> git pull upstream <branch>
It is important to know that the above commands will only update the local git copy, the remote of the fork will not be updated. To keep both the local and the remote repositories up-to-date, make sure to do a git push
after syncing.
Please follow the following instructions to set up a development environment for extension development.
As a TypeScript project, this extension has dependencies on:
After installing node
(and npm
), clone the repository.
git clone https://github.com/ms-iot/vscode-ros
It is recommended to sync with upstream and update dependencies by running npm ci
before making changes.
It is recommended to use npm ci
instead of npm install
.
This is because npm ci
consumes package-lock.json
to ensure the same version is used for all nested dependencies.
cd vscode-ros
# sync with upstream
npm ci
code .
You can now go to the Debug viewlet (Ctrl+Shift+D
), select Extension
, and then hit run (F5
).
This will open a new VS Code window which will have the title [Extension Development Host]
.
In this window, open any ROS workspace.
In the original VS Code window, you can add breakpoints which will be hit when they are executed.
If you make edits in the extension .ts
files, just reload/restart (Ctrl+Shift+F5
) the [Extension Development Host]
instance of Code to load in the new extension code. Similarly, you could also execute the Developer: Reload Window
command through command palette in the [Extension Development Host]
instance.
The debugging instance will automatically reattach.
To run the tests locally, open the Debug viewlet (Ctrl+Shift+D
), select Tests
, then hit run (F5
).
After making changes locally, you might want to test it end to end.
To do this, you can sideload the extension.
This can be done by packaging the extension and loading the .vsix
directly.
In the workspace, follow these steps:
npm install -g vsce
npm ci
vsce package
Then in any VS Code instance, run the command Extensions: Install from VSIX...
.
Choose the .vsix
file generated in the previous step
Please check release instructions in maintainers' guidelines.
This project welcomes contributions and suggestions. Most contributions require you to agree to a Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us the rights to use your contribution. For details, visit https://cla.microsoft.com.
When you submit a pull request, a CLA-bot will automatically determine whether you need to provide a CLA and decorate the PR appropriately (e.g., label, comment). Simply follow the instructions provided by the bot. You will only need to do this once across all repositories using our CLA.
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.