Skip to content

xuanvu/omnisharp-sublime

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

OmniSharpSublime for ST3

OmnisharpSublime is a plugin for ST3 to provide a C# development environment. It communicates with OmniSharpServer by nosami for IDE functions.

It works on:

  1. Mac OSX
  2. Linux
  3. Windows (needs Python installed)

Features

  1. Auto OmniSharpServer running
  2. Asynchronous communication with OmniSharpServer (Never freeze!)
  3. Auto Completion
  4. Goto definition
  5. Rename
  6. Goto implementation
  7. Syntax/Semantic error highlighting
  8. Displays possible override methods
  9. Find Usages
  10. Format Document
  11. Displays code issues such as assigment is redundant
  12. Fix code issues - put cursor on highlighted issue and select Fix Code Issue
  13. Remove Unused, Add Missing and Sort Using Statements
  14. Code Actions eg. Convert LINQ query to Fluent Syntax
  15. Add File To Project
  16. Remove File from Project (via sidebar and context menu)
  17. Add New C# Class & Interface (via sidebar and context menu) via File Templates which also adds to csproj
  18. Type Lookup with Documentation
  19. Hide/Show Info Panel
  20. Run Unit Tests
  21. Build/ReBuild/Clean Solution

#Requirements

#Installation

  • Using the Sublime Package Manager install the package called OmniSharp

Building From Source

  1. Move to ST3 plugin directory in console.

     cd {path to ST3 plugin directory}/Packages
    
  2. Clone repository.

     git clone https://github.com/OmniSharp/omnisharp-sublime.git OmniSharp
    
  3. Move to plugin directory, update submodule and build.

     cd OmniSharp
     git submodule update --init --recursive
     ./build.sh
    

Project Setting

To run server automatically, you have to specify a solution file in a sublime-project. For ASP.Net vNext applications you do not need to specify the solution file but you need the sublime-project file.

Let's assume you already have a solution.

Go to `File -> Open` and select the folder with your solution in it.

Go to `Project -> Save Project As` and save a YOURPROJECTNAME.sublime-project in the same location as your *.sln

Open your YOURPROJECTNAME.sublime-project file that should now appear in the sidebar on the left

Enter the location to the *.sln file like below

Example of a sublime-project

{
    "folders":
    [
        {
            "follow_symlinks": true,
            "path": "."
        }
    ],
    "solution_file": "./testconsoleprj.sln"
}

Once the YOURPROJECT.sublime-project is set up and saved follow the below:

Close Sublime (YMMV but this seems to be the best way to open the .sublime-project)

Open Sublime

Click `Project -> Open Project`, and select your YOURPROJECT.sublime-project file

C# language-specific settings

Create C# settings file as shown in this picture

Imgur

Paste the below in. This will launch intellisense on . and < symbols

{
   "auto_complete": true,
   "auto_complete_selector": "source - comment",
   "auto_complete_triggers": [ {"selector": "source.cs", "characters": ".<"} ],
}

#OmniSharpServer Settings The Sublime plugin communicates to OmniSharp Server which has various available settings stored in a config.json file. By default the location of this file is in a folder under the Sublime OmniSharp packages folder called PrebuiltOmniSharpServer and there is also a user specific plugin setting that specifies the location of this config.json file. To prevent your settings being overridden on new releases of the Sublime package, we recommend you store your config.json file somewhere other than the default location. Once you have taken a copy of config.json and put it somewhere safe you will need to update the Sublime plugin's user setting called "omnisharp_server_config_location".

#Format Document Settings

When you press Ctrl + K + D to format the document you may see CR markers.

CR Markers

This is to do with the settings for OmniSharpServer.

Click Preferences - Browse Packages
Go to `OmniSharp/PrebuiltOmniSharpServer/` sub directory 
Open config.json and modify the `eolMarker` setting to `\n` like below

OR

   Open your safely tucked away config.json file and modify the `eolMarker` setting to `\n` like below
  "TextEditorOptions": {
    "tabsToSpaces": true,
    "tabSize": 4,
    "indentSize": 4,
    "continuationIndent": 4,
    "labelIndent": 0,
    "eolMarker": "\n",
    "indentBlankLines": false,
    "wrapLineLength": 80
  },

#Unit Tests

For the plugin to be able to run unit tests you need to configure the test runner. This is done in the server config file.

Click Preferences - Browse Packages
Go to `OmniSharp/PrebuiltOmniSharpServer/` sub directory 
Open config.json and modify the `TestCommands` like below

OR

 Open your safely tucked away config.json file and modify the `TestCommands` like below
  "TestCommands": {
   "All": "nunit-console.exe -nologo {{AssemblyPath}}",
   "Fixture": "nunit-console.exe -nologo {{AssemblyPath}} -run={{TypeName}}",
   "Single": "nunit-console.exe -nologo {{AssemblyPath}} -run={{TypeName}}.{{MethodName}}"
  },

Sometime

  • Show Documentations
  • Find type / symbols
  • advanced syntax highlight

Packages

No packages published

Languages

  • Python 99.8%
  • Shell 0.2%