Microsoft Endorsing C# as a First Class Citizen in Sublime Text
At the end of my last post on using ASP.Net vNext with Sublime Text I briefly mentioned a plugin that aimed at giving intellisense for C# within the editor. Well 2 months later and I’m happy to announce that intellisense works and I’ve added a slew of other features that will hopefully make you feel at home away from Visual Studio.
I discovered the plugin thanks to Jason Imison but at that point there was some issues getting the intellisense working consistently because at that time I was using it with an ASP.NET vNext application which didn’t have a solution file (*.sln) and the plugin was expecting that. After speaking to Jason I found out I could change the settings so it wouldn’t expect a solution file and give me the intellisense I was after in a text editor. Eureka, it worked! I was now on a mission to make Sublime be a first class citizen when writing C#. Some may question why on earth would I want to edit C# in something other than Visual Studio. I don’t really want to get into that debate here but all I’ll say is, it’s nice to have other editor options and with Microsoft’s mission to provide vNext compatibility with Mono and Visual Studio not running on OSX/Linux it makes sense to have an editor with feature rich C# support (yes I know there is Xamarin Studio but “options” people, “options”).
How does it work?
I should really introduce Jason Imison. Jason is the author of a library called OmniSharpServer which is a -
HTTP wrapper around NRefactory allowing C# editor plugins to be written in any language.
NRefactory is the C# analysis library used in the SharpDevelop and MonoDevelop IDEs. It allows applications to easily analyze both syntax and semantics of C# programs. It is quite similar to Microsoft’s Roslyn project; except that it is not a full compiler – NRefactory only analyzes C# code, it does not generate IL code.
In simple terms OmniSharpServer is a local web server (written in Nancy) that accepts requests to various different endpoints which returns results about the code you sent to it. For example, in Sublime Text when you have a string variable and you type .
after the variable a request is sent to OmniSharpServer with a specific payload and the response contains all the possible completions for that variable.
The editor plugin is responsible for initiating the requests and dealing with the response in order to provide the user a rich user experience for editing C# and this is hopefully what I have done with OmniSharpSublime.
Getting Started
For Mac & Linux users you will need Mono installed.
For Windows users you will need Python installed and in your PATH.
Well versed users in Sublime know there is a package manager that allows you to easily install plugins. In the package manager if you search for OmniSharp you will see the plugin avaiable for install. Install and away you go! Please note that I would not consider the plugin a stable release, its close but not quite there yet.
As I mentioned earlier you can use OmniSharpSublime with a traditional C# solution or with an ASP.Net vNext project (that does not require a solution file) however, you will need a 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
Your .sublime.project
file should look like this
{
"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 YOURPROJECTNAME.sublime-project)
Open Sublime
Click "Project -> Open Project", and select your YOURPROJECTNAME.sublime-project file
Now with the sublime.project
open you should be ready to edit your *.cs
files.
There is one last “nice touch” to add to Sublime before you edit your files. Sublime allows syntax specific settings so for C# it would be great if we could invoke intellisense when we type a full stop.
Click "Sublime Text -> Preferences -> Settings - More -> Syntax Specific - User"
Paste in the below code and save
{
"auto_complete": true,
"auto_complete_selector": "source - comment",
"auto_complete_triggers": [ {"selector": "source.cs", "characters": ".<"} ],
}
Now you’re ready to rock!
Features
Below I will highlight some of the cool features of OmniSharpSublime by the power of animated gifs (hope you have a decent internet connection, sorry!)
Intellisense
This is probably one of the most important features that springs to mind when editing a C# file in a text editor.
Go To Definition
Rename
Find Usages
Go To Implementation
Format Document
Checkout the key binding!
Override
Add Reference
Syntax Errors
Semantic Errors
Code Issues
Fix Code Issues
Fix Using Statements
Code Actions
Checkout the key binding for Resharper lovers!
Add New C# File
There is also add new C# interface and you can add your own templates!
Type Lookup
Build Solution
You can press F4 & Shift+F4 to cycle through the errors reported!
Unit Tests
Add/Remove from Project
If you create an empty chsarp file or paste a file into the folder, if you open it up and simple save the file it will be added to the *csproj
file. You can also right click a file and choose Remove from Project
and this will remove the file from a *.csproj
file.
OSS FTW!
Hopefully that’s given you a taste of what the plugin can do and I hope you think its as cool as I do. I believe that this will give users another option when deciding what editor to use when editing C# files. A big thanks to Jason Imison for OmniSharpServer which allows the plugin to provide all the code options and for him putting up with my questions.
If you’re interested please download the plugin and enjoy it. Please let me know of any issues or features you think need adding, I already have plenty in my head but I’m sure there are more additions we can add to make the plugin better and better. Some documentation can be found here.
Also thanks to the guys who originally came up with the idea of the plugin and to the other contributors who have already submitted pull requests.
Microsoft & OSS
This blog post and project has been sitting on my file system for probably 4-5 weeks ready to be published but during that time I’ve had chance to make new friends and add new features which I’ve shown you above!
Question: Why did I wait 4-5 weeks to publish this post?
Answer : Microsoft!
Since my last blog post I’d been in touch with the authors of the Kulture plugin (Sayed Ibrahim Hashimi) who just happened to work for Microsoft. They liked my Nancy yeoman generator and I managed to convince them to merge my generator with their ASP.Net generator. I asked a few questions here and there and Jason Imison came onboard, then Martijn Laarman showed some interest in getting intellisense working and soon we started growing something. David Fowler was brought in to answer some questions and we started having Skype chats with Scott Hanselman and we then decided upon the path we were going to take. OmniSharp was born!
OmniSharp
Our path was going to be make C# available on all the popular editors. Soon we had Stephen James and Martijn Laarman working on making OmniSharp work with Atom, Jason Imison working with Vim, Simon Carter, Mika Vilpas & Jason Imison on Emacs, Mat McLoughlin on Brackets and me on Sublime.
We then moved all our repositories to an OmniSharp Github organization
We built a website
We created a twitter account
We created a Jabbr room
Lets just make this clear, Microsoft were working with us to publicise and demonstrate C# working on all the major editors where we predominantly used them on OSX so Mono was going to be needed and they were happy about this!
Hang on, why did you have to wait 4-5 weeks to release the blog post?
The reason was that Microsoft were going to have a big announcement to make on November 12th 2014 and it was going to be that the .NET CLR was going to be built as a cross platform and open source tool and that they were going to demonstrate the work we’d been doing on OmniSharp as part of this announcement so we decided after that we’d go public so to speak!
WHAT?!
That’s right, .NET is going OSS & cross platform! HUGE NEWS and we were working as part of an OSS team with Microsoft to highlight that you can use any editor you like to build .NET applications on any platform. It appears Leopards can change their spots. Lets hope this new open Microsoft will continue for many years to come!
Taking OmniSharp forward
Jason has started working with the Design Time Host that is used for ASP.NET vNext projects which provides information about vnext assemblies and this will be integrated into OmniSharpServer and there are areas already in OmniSharpSublime that I have highlighted that need to become more vNext focused. Sayed is making changes to Kulture such as intellisense in project.json for NuGet packages, maybe our two projects will merge. NRefactory are looking to use Roslyn for the code analysis engine underneath which effects OmniSharpServer. I’m hoping that OmniSharp will become an OSS success for all of us to gain from and I hope you will want to be apart of it.
Conclusion
So there you have it, C# as a first class citizen in Sublime Text, .Net as a cross platform tool and .Net going open source. What a day!
Enjoy!
Scott Hanselman has posted his views on OmniSharp and a cross platform OSS .NET here
Mat McLoughlin has posted information on the Brackets plugin here
Martijn Laarman has posted information on the Brackets plugin here
Leave them wanting more!
I’ve been spiking NuGet support for Sublime and here’s a brief intro