Skip to content

Latest commit

 

History

History
132 lines (85 loc) · 4.59 KB

CONTRIBUTING.md

File metadata and controls

132 lines (85 loc) · 4.59 KB

How to Contribute

Contributions are essential for keeping this extension great. We try to keep it as easy as possible to contribute changes and we are open to suggestions for making it even easier. There are only a few guidelines that we need contributors to follow.

Development

Installation Prerequisites:

Steps

  1. Fork and clone this repository

  2. Fork and clone the LemMinX - XML Language Server

  • Note: The directory format has to match the following:

      YOUR_FOLDER/
                ├──── lemminx/
                │
                ├──── vscode-xml/
    
  1. cd lemminx/

  2. Install the maven dependencies Mac/Linux:

    $ ./mvnw verify

    or for Windows:

    $ mvnw.cmd verify
  3. cd vscode-xml/

  4. Install the dependencies:

    $ npm install
  5. In vscode-xml/, build the server by running:

    $ npm run build-server
  6. To run the extension, open the Debugging tab in VSCode.

  7. Select and run 'Launch Extension (vscode-xml)' at the top left:

     Launch Extension

Debugging Language Server

After completing the prerequisite steps above, and after launching the Extension Development Host for vscode-xml, you can also debug the language server/lemminx and can be used as follows:

On VSCode

  1. Ensure that the most recent changes of lemminx have been built before launching the Extension Development Host (as per Step 7 in Steps), and that the Extension Development Host is running.

  2. Open lemminx in VSCode. This should display the "Debug (Attach) - Remote" option in the "Debugging" tab.

  3. To run the debugger, open the "Debugging" tab in VSCode.

  4. Select and run "Debug (Attach) - Remote" at the top left:

Debug Attach Remote

This will make the lemminx debugger attach to the Extension Development Host instance.

To confirm that the debugger has properly attached, the "Call Stack" dropdown in the "Debugging" tab should be populated as follows:

Debug Menu Call Stack

Now that the lemminx debugger is properly attached, any language server interactions can be debugged and breakpoints in lemminx will be tracked.

Binary server development

Testing a binary version of LemMinX

  1. Copy the binary version of LemMinX to:

    OS Location (relative to root of repository)
    Linux ./server/lemminx-linux
    macOS ./server/lemminx-darwin-x86_64
    Windows .\server\lemminx-win32.exe

    Alternatively, you can set the xml.server.binary.path preference to specify the path of the binary to run.

  2. Make sure that you set xml.server.preferBinary to true, disable any LemMinX extensions by commenting out xml.extension.jars in your settings.json, and uninstall or disable any VS Code extensions that provide extra LemMinX features.

  3. Launch vscode-xml in development mode, and double check that the binary server is running by checking the server logging (Output > XML Support)

Downloading the GitHub Actions binary for your PR

  1. Open the GitHub page for your PR.

  2. Click on "Checks":

  3. Click "Artifacts", then select the binary for your operating system:

Building a binary with GraalVM locally

If you submit a LemMinX PR, GitHub Actions will generate a binary for your PR that you can use for testing. If you need to generate a LemMinX binary locally for whatever reason, follow these steps:

  1. Download and set up GraalVM and its dependencies
    • The latest version should work
  2. Make sure that the environment variable JAVA_HOME points to the GraalVM installation.
  3. Run ./mvnw clean package -DskipTests -Dnative from the root of the LemMinX repository
    • This will use a lot of memory (> 4 GB) and take a while
  4. The binary is generated in ./org.eclipse.lemminx/target

Certificate of Origin

By contributing to this project you agree to the Developer Certificate of Origin (DCO). This document was created by the Linux Kernel community and is a simple statement that you, as a contributor, have the legal right to make the contribution. See the DCO file for details.