Skip to content

A tool to import Zephyr code into Visual Studio Code in the context of a Zephyr application

License

Notifications You must be signed in to change notification settings

smrtos/Zephyr2VSC

Repository files navigation

Introduction

Visual Studio Code is a cross-platform IDE.

This tool imports Zephyr (https://github.com/zephyrproject-rtos/zephyr ) source code into Visual Studio Code in the context of a build.

A build must be made before using this tool because certain dependent files are only generated after a build.

This tool can run on both Windows and Linux.

What you will get via this tool

  • Exclusion of C files irrelevant to a specific Zephyr build
  • Intellisense support
  • Unambiguous symbol resolution
  • Goto definition/declaration easily
  • Rich VS Code extensions
  • etc.

Notes

This tool will exclude files which are NOT relevant to the selected build context.

But the file exclusion is only done for .c files. Not for other files.

So if you open arbitrary files such as a .h file, that file may NOT be relevant to the current build.

So the symbols in that file may NOT be fully resolved.

In future I may expand the scope of irrelevant file exclusion.

But for .c file browsing, it suffices, I think.

Pre-requisites

  1. Install VS Code

    Windows: https://code.visualstudio.com/docs/?dv=win

    Linux: https://code.visualstudio.com/docs/?dv=linux64_deb (Ubuntu like)

  2. Install VSCode C/C++ Extension:

    https://code.visualstudio.com/docs/languages/cpp

  3. Install Python 3: https://www.python.org/downloads/release/python-373/

Usage

  1. Download and extract the zip.

  2. Goto the extracted folder.

  3. Run python -m zephyr2vsc to see the usage info and run it.

    zephyr2vs.usage

  4. Open the zephyr source dir with VS Code. And wait for the database icon at the bottom right to disappear.

    It takes less than 1 min on Windows. Linux is even faster.

    This icon indicates that VS Code is parsing the files in the background.

    You can hover the mouse on it to see the progress.

    file parsing icon

A sample run

zephyr2vs.run

Known issues

  1. Below VS Code C/C++ extension bug is not fixed. Currently using a workaround.

    microsoft/vscode-cpptools#4063

  2. Below VS Code C/C++ extension bug used to be an issue but has been fixed. Please use VS Code c_cpp_extension >= 0.25.1.

    microsoft/vscode-cpptools#4095

  3. Do not change the driver letters with subst command on Windows after a Zephyr build is made.

    Because the .ninja files uses absolute path and the new driver letter will break the relative path handling.

Development

  • Create a virtual environment:
    • Windows: python -m venv venv
    • Linux: python3 -m venv venv
  • Activate the virtual environment:
    • Windows: . venv/scripts/activate
    • Linux: . venv/bin/activate
  • Install the development dependencies to the virtual environment:
    • pip install zephyr2vsc[dev]

Testing

About

A tool to import Zephyr code into Visual Studio Code in the context of a Zephyr application

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •  

Languages