question-mark
Stuck on an issue?

Lightrun Answers was designed to reduce the constant googling that comes with debugging 3rd party libraries. It collects links to all the places you might be looking at while hunting down a tough bug.

And, if you’re still stuck at the end, we’re happy to hop on a call to see how we can help out.

OmniSharp Status Bar Icon should be Workspace-level element

See original GitHub issue

The existing Status Bar element displayed by this extension is a bit confusing, both from a user’s perspective as well as the maintainer’s. For reference, the element is this: image

The element is confusing because it represents workspace-wide state but attempts to do so in relation to the Active Text Editor. More specifically, the Status Bar element is only visible if the Active Text Editor is one that O# does/should care about. However, the status bar element communicates the status of the Workspace’s O# server, something that is largely independent of the currently active document.

The status element’s split intent leads to several undesirable characteristics which we should solve:

  • Though O# is running all the time, the status bar suggests that it’s only running while .NET files are open.
  • By appearing in the context of .NET files only, the element suggests that its action [switching projects] is somehow relative to the currently selected document. This is not true, as that action is displaying projects at the VS Code Workspace level.
  • Existing filters used to choose if the element should be shown can lead to odd and confusing states. A key example occurs if one opens a .NET file from outside the current workspace. This causes the element to show the text Switch Projects though it is impossible to select a project that covers the active file. This results in an infinite loop in UX actions.

Proposal

The O# status bar element should be converted to represent the status of the O# server at the VS Code context. This means:

  • Move the element to the left, along with other Workspace-context tools like GIT and the VS Code Problem Reporter
  • The element should appear once the extension is initialized and should remain visible at all times unless the O# server is explicitly stopped
  • The element itself should be explicitly split to represent two concerns:
    • The flame icon should represent the status of the O# server. It should be the default color if things are going well, and should be red if a problem occurs. Clicking the icon should take users to the appropriate output channel.
    • The text should represent the project currently open in the O# server. This element can be in one of several states:
      • Not ready. This includes Downloading, Installing, Starting, and Stopping. The text should express the state that the server is in. Clicking the text should have no effect.
      • Select Project. When the server starts but realizes it does not know which project to open, it must prompt the user. In this state the flame icon should be Yellow in this state. Clicking this text should allow the user to select a project.
      • Running. When the server is running on a specific project, the text will display the name of that project. Clicking on the text should allow the user to select a different project.

Issue Analytics

  • State:closed
  • Created 5 years ago
  • Reactions:4
  • Comments:6 (3 by maintainers)

github_iconTop GitHub Comments

3reactions
akshita31commented, Mar 30, 2018

I think we can segregate the two into two separate status bar items:

  1. Omnisharp Server Status: This activates as soon as we activate the extension and shows the status of the Omnisharp server.
  • Downloading
  • Installing
  • Starting
  • Running
  • Error This will stay throughout the lifetime of the extension.
  1. Project Status: Displays the status of the project open in the current workspace.
  • Select Project. When the server starts but realizes it does not know which project to open, it must prompt the user. In this state, the flame icon should be Yellow in this state. Clicking this text should allow the user to select a project.
  • Project Name: When the server is running on a specific project, the text will display the name of that project. Clicking on the text should allow the user to select a different project.
1reaction
akshita31commented, Mar 29, 2018

Yes, vscode recognises the following set of icons: https://octicons.github.com/. We can use them at appropriate places.

Read more comments on GitHub >

github_iconTop Results From Across the Web

VS code: tell omnisharp which project/solution to work on
Press Ctrl + Shift + P in VS Code. Type “OmniSharp: Select Project” and press Return. Select the top level sln or csproj....
Read more >
Language Server Protocol Specification - 3.17
This mechanism can be used to report any kind of progress including work done progress (usually used to report progress in the user...
Read more >
Contrib / Neovim / nvim-lspconfig - Explore · GitLab
This repo is (1) a place for Nvim LSP users to collaboratively provide starting examples for the many LSP backends out there, and...
Read more >
Vsc, Visual Studio Code - Extensions - infos
C# for Visual Studio Code (powered by OmniSharp). ... See git blame information in the status bar. ... A vscode extension for Element-UI...
Read more >
Visual Studio Code - PDFCOFFEE.COM
You can find more details about the interactions with source control in Chapter 5. The last two icons on the left side of...
Read more >

github_iconTop Related Medium Post

No results found

github_iconTop Related StackOverflow Question

No results found

github_iconTroubleshoot Live Code

Lightrun enables developers to add logs, metrics and snapshots to live code - no restarts or redeploys required.
Start Free

github_iconTop Related Reddit Thread

No results found

github_iconTop Related Hackernoon Post

No results found

github_iconTop Related Tweet

No results found

github_iconTop Related Dev.to Post

No results found

github_iconTop Related Hashnode Post

No results found