/VioletToGreen

Primary LanguageJavaMIT LicenseMIT

VioletToGreen

About

VioletToGreen is a VS Code extension that leverages a novel method of linking comments to code, suggesting where to insert comments and reminding the developer to update comments when corresponding code is updated, to improve understandability and maintainability of code.

Demo Video

Abstract

The aim of the project is to improve understandability and maintainability of the code by leveraging the comments written by the user. Developers often tend to forget to update the corresponding comments after updating the code, which leads to less maintaiability over time. Our tool aims at tackling this problem in a novel way. The tool is delivered in the form of a VS Code extension which helps the programmer maintain the readability on the fly. The tool has 2 main features i.e, automatically linking the comments and code, and suggesting where to insert a commnet based on a custom readability metric. The linking of comments is done in both manual and automatic ways. For manual linking, appropriate GUI has been implemented and these links will be stored in a file. For automatic linking, a few heuristic rules have been devised based on the commenting habits of a typical programmer keeping mind various cases possible including some anomalous ones. For insert comment suggestion functionality, we are analysing various source code components (functions, blocks, loops, etc.) and predicting readability score. We use this readability score along with the code-to-comment ratio to decide whether a comment is needed or not, based on a threshold value for both the metrics. Once the linking is done, in the future if the user edits a piece of code that is linked, the tool prompts the user to update the corresponding comment. This linking is also useful when a programmer is trying to understand a code base, in which case the tool helps the user to visualize exactly which part of the code is linked to which comment.

Objectives

The main objectives of the tool include linking code to comment either manually or automatically. Prompting the user to update a particular comment after the linked code has been modified. Suggests where to insert a comment based on the custom readability score.

UI Features

  1. As soon as the extension is active, a dedicated side panel opens up with three sub panels.

  1. Highlight a comment or a code snippet and click on Select to select and link them.

  1. Click on Link to link them. The linked snippets will be displayed in the LINKS panel.
  2. Placing the cursor on either the linked comment will highlight the corresponding code snippet and vice-versa. Comments are highlighted in blue and code snippets in green.

  1. If a highlighted region is edited by the user, the linked region will also adapt to include or exclude the new set of lines.
  2. A link can also be present across two different files. The path of each snippet in each link will be displayed in the tooltip component.
  3. Clicking on the blue and green regions on the side panel will make the editor navigate to the appropriate linked positions by displaying the comment on the left and the corresponding code snippet on the right of a split window.

  1. The links panel also displays the automatically created links invoked by the user.
  2. Any link can be deleted by clicking on the delete icon of the corresponding link on the left panel.
  3. The links are saved in a config file so that the links will persist in all sessions of VS Code. The config file can also be shared with different users so that they will also be provided with the same links and highlights.
  4. The middle panel hosts the functionality to display suggestions on where to insert comments, which is invoked by the user.

  1. Each list item in the middle panel is clickable and navigates to the position of the suggestion upon clicking.

  1. Each suggestion also adds an information squiggle in the editor wherever a comment insertion is required. Upon hovering, a hover box appears which displays the relevant grasp score of that code snippet.

  1. The suggestions can be individually resolved by clicking on the tick icon on the right. This will delete that particular suggestion from the list.
  2. The extension displays a warning message in case the user has modified the code and has not modified the corresponding linked comment. This check is triggered after every save file event.

Other Features

  1. The extension becomes active on VS Code startup and the webview side panel will open up.
  2. The links generated are stored in a file called violettogreen.config.json. Sharing this file will enable other users to view all the links created by different users.
  3. The Link Automatically command sends the code to the server which runs an ML model to detect whether a comment is a commented out code snippet or not.
  4. The Suggest Insert Comments also sends the code to the server that parses the file and calculates the RUM metric, comment to code ratio for each sample snippet and returns this value to the client.

Instructions

  1. Clone this repository.
  2. Run the following commands:
$ npm install
$ npm run watch
  1. Click on F5 to run.
  2. Clone the server repository in a different directory.
  3. Run the following to start the server:
$ node server

Commands

  1. Link Automatically will link comments and code snippets automatically based on carefully laid out heuristics.
  2. Suggest Insert Comments will evaluate the currently open file based on the RUM metric and provide a list of suggestions on comment insertion.