Code Monkey home page Code Monkey logo

omnisharp-emacs's Introduction

OmniSharp

OmniSharp Organization repo for project coordination, global communication and other organizational topics.

Please do not use this repo to open bugs/support issues - use the project repository relevant to the product you are using (e.g. C# Extension for VS Code, VIM plugin, Emacs plugin, OmniSharp server and so on) instead.

License

Copyright © .NET Foundation, and contributors.

OmniSharp is provided as-is under the MIT license. For more information see LICENSE.

Code of Conduct

This project has adopted the code of conduct defined by the Contributor Covenant to clarify expected behavior in our community. For more information see the .NET Foundation Code of Conduct.

Contribution License Agreement

By signing the CLA, the community is free to use your contribution to .NET Foundation projects.

.NET Foundation

This project is supported by the .NET Foundation.

omnisharp-emacs's People

Contributors

alistair avatar andyleejordan avatar arialdomartini avatar bbbscarter avatar bsuh avatar corngood avatar cpitclaudel avatar damiencassou avatar dgalizzi avatar dgutov avatar grendello avatar jcs090218 avatar jesse-black avatar jimhansson avatar jordonbiondo avatar josteink avatar jtbm37 avatar juergenhoetzel avatar lafleurh avatar m-frankied avatar mikavilpas avatar nosami avatar pcrama avatar razzmatazz avatar retran avatar simongr avatar supermomonga avatar syohex avatar yaruopooner avatar ylluminarious avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

omnisharp-emacs's Issues

Make API calls asynchronous

There are a few API calls that can be asynchronous. Examples of these
are

  • omnisharp-go-to-definition
  • omnisharp-find-implementations
  • ???

I hazily recall there is an indirect dependency to the library
deferred.el. That is required by one of the dependencies of
omnisharp-emacs. Maybe that library offers something that will tackle
this problem easily.

Unable to add new files to a project

Running (omnisharp-add-to-solution-current-file) doesn't seem to do work on the Emacs side. On the server side we get the following debug spew:

System.InvalidOperationException: Operation is not valid due to the current state of the object
at System.Linq.Enumerable.First[IProject](IEnumerable1 source, System.Func2 predicate, Fallback fallback) [0x00000] in :0
at System.Linq.Enumerable.First[IProject](IEnumerable1 source, System.Func2 predicate) [0x00000] in :0
at OmniSharp.Solution.CSharpSolution.ProjectContainingFile (System.String filename) [0x00000] in :0
at OmniSharp.ProjectManipulation.AddToProject.AddToProjectHandler.AddToProject (OmniSharp.ProjectManipulation.AddToProject.AddToProjectRequest request) [0x00000] in :0
at OmniSharp.ProjectManipulation.AddToProject.AddToProjectModule+c__AnonStorey11.<>m__1D (System.Object x) [0x00000] in :0
at Nancy.Routing.Route.Invoke (Nancy.DynamicDictionary parameters) [0x00000] in :0
at Nancy.Routing.DefaultRouteInvoker.Invoke (Nancy.Routing.Route route, Nancy.DynamicDictionary parameters, Nancy.NancyContext context) [0x00000] in :0
at Nancy.Routing.DefaultRequestDispatcher.Dispatch (Nancy.NancyContext context) [0x00000] in :0

Add interactive renaming

This would let the user see how the changes are applied.
Emacs ships with a very nice interface for this, but it's bundled
with the dired package - dired-do-query-replace-regexp.

It only works for the currently marked files in dired, but it uses
tags-query-replace internally. This should be very easy to integrate
to solutions since we already have a way of getting all the files in
the current solution.

Add feature: manual syntax check

I think it may be possible to do this by refactoring the existing
flycheck checker error parser out to its own function and calling
that.

JSON readtable error

I get this error when I connect to Omnisharp server. I had built the server using VS 2010.

Interestingly, this problem didn't happen when I built the solution using VS 2012. Not sure if this is really relevant. Here's the error ouput in the *Messages* buffer.

  #creditsContainer a
  {
    color: #777777
  }

  #errorToggle
  {
    float:right;
  }

  #errorToggle a
  {
    color: #777777;
  }

  #errorDetails
  {
    width: 100%;
    margin: 24px;
    text-align: left;
    display: none;
  }

  .clear {
    clear: both;
    height: 0px;
    margin: 0;
    padding: 0;
    visibility: hidden;
  }
  </style>

  <!--[if lt IE 8]>
  <style type="text/css">
    #embeddedImage {
      visibility: hidden;
    }
  </style>
  <![endif]-->

  <script type="text/javascript">
    function ShowHideDetails() {
      var details =  document.getElementById('errorDetails');

      if (details.style.display == 'block') {
        details.style.display = 'none';
      } else {
        details.style.display = 'block';
      }
    }
  </script>
</head>
<body>
  <div id="mainContainer">
    <div id="errorContainer">
      <div id="errorImage">
        <img id="embeddedImage" src="" width="115" height="150">
      </div>
      <div id="errorText">
        <h1>500 - InternalServerError</h1>
        <p>Something went horribly, horribly wrong while servicing your request.</p>
        <p>We're sorry :-(</p>
      </div>
      <div class="clear"></div>
    </div>
    <div id="creditsContainer">
      <p>Graphics courtesy of the awesome <a href="http://theoatmeal.com/" target="_blank">Matthew Inman</a> </p>
    </div>
    <div id="errorToggle"><a href="javascript:ShowHideDetails();">Details</a></div>
    <div class="clear"></div>
  </div>
  <div id="errorDetails">
    <h2>Error Details</h2>
    <pre id="errorContents">Nancy.RequestExecutionException: Oh noes! ---> System.ArgumentNullException: Value cannot be null.
Parameter name: text
   at ICSharpCode.NRefactory.Editor.StringTextSource..ctor(String text)
   at ICSharpCode.NRefactory.CSharp.CSharpParser.Parse(String program, String fileName)
   at OmniSharp.SyntaxErrors.SyntaxErrorsHandler.FindSyntaxErrors(Request request) in C:\Users\awali\OmniSharpServer\OmniSharp\SyntaxErrors\SyntaxErrorsHandler.cs:line 11
   at OmniSharp.SyntaxErrors.SyntaxErrorsModule.<>c__DisplayClass2.<.ctor>b__0(Object x) in C:\Users\awali\OmniSharpServer\OmniSharp\SyntaxErrors\SyntaxErrorsModule.cs:line 14
   at Nancy.Routing.DefaultRouteInvoker.Invoke(Route route, DynamicDictionary parameters, NancyContext context)
   at Nancy.Routing.DefaultRequestDispatcher.Dispatch(NancyContext context)
   at Nancy.NancyEngine.InvokeRequestLifeCycle(NancyContext context, IPipelines pipelines)
   --- End of inner exception stack trace ---
   at Nancy.NancyEngine.InvokeOnErrorHook(NancyContext context, ErrorPipeline pipeline, Exception ex)</pre>
  </div>
  <script type="text/javascript">
      var toggle = document.getElementById('errorToggle');
      var errorContents = document.getElementById('errorContents');

      if (errorContents.innerText == '') {
          toggle.style.display = 'none';
      }
  </script>
</body>
</html>

Error: JSON readtable error

The error originates from the server. Here's the stacktrace from the server program's console output.

System.ArgumentNullException: Value cannot be null.                         
Parameter name: text                                                           
at ICSharpCode.NRefactory.Editor.StringTextSource..ctor(String text)        
at ICSharpCode.NRefactory.CSharp.CSharpParser.Parse(String program, StrinleName)                                                                        
at OmniSharp.SyntaxErrors.SyntaxErrorsHandler.FindSyntaxErrors(Request ret) in C:\Users\awali\OmniSharpServer\OmniSharp\SyntaxErrors\SyntaxErrorsHandcs:line 11                                                                     
at OmniSharp.SyntaxErrors.SyntaxErrorsModule.<>c__DisplayClass2.<.ctor>b_bject x) in C:\Users\awali\OmniSharpServer\OmniSharp\SyntaxErrors\SyntaxErrodule.cs:line 14                                                                
at Nancy.Routing.DefaultRouteInvoker.Invoke(Route route, DynamicDictionarrameters, NancyContext context)                                                
at Nancy.Routing.DefaultRequestDispatcher.Dispatch(NancyContext context)    
at Nancy.NancyEngine.InvokeRequestLifeCycle(NancyContext context, IPipelipipelines)

Any clue about this? Thanks in advance.

Add flycheck checker for compilation errors

This could be chained after the syntax errors checker.
That way quick and obvious errors will not trigger a compilation,
which is likely a much more heavy operation.

We already have the means for getting a build command both on
UNIX and Windows systems. This could be fed to the checker.

Upgrade screenshots to GIFs

Most screenshots show something that happens in relation to
something that has happened earlier. These would be much better
to show as animated images.

Add option for installing dependencies automatically from MELPA

MELPA is an elisp package repository that
has a lot of ready-to-install elisp packages. These can be installed
in emacs with an integrated GUI, are easy to store in personal version
control systems and just work.

To simplify installation, omnisharp-emacs should be submitted as a new
recipe. This, as I currently understand it, will enable
omnisharp-emacs to be downloaded from MELPA via M-x package-install.

The qualifications for submitting a new package are located at the
source repository README:

https://github.com/milkypostman/melpa

ELDoc support

It would be great to have ELDoc support, so Emacs shows the type of the symbol at point at all times.

Implemented, creating a pull request.

Add feature: rename current file

Example interface to user:

"Rename current file to: (defaults to old name)"
"Renamed (old-file-name) to (new-file-name). Delete old file? (y or n)"

Rough plan:

Should save the current file, then

  • remove old-file-name from project
  • save current file with new-file-name
  • add new-file-name to project
  • ask if user wants to delete old-file-name (that is now not included
    in the project), and delete it if they want to.

Keep showing auto-complete documentation after popup is closed

Currently the auto-complete documentation is only shown when the popup
window is active. But when the user chooses a completion, the
documentation is closed. This is annoying when writing method calls,
since I'd like to be able to look at the documentation to see what
arguments to pass.

Tasks:

  • Find a way to persistently show documentation. popup-menu-keymap has
    a setting for this, but last time I tried I couldn't get it to
    work. For now the UI can be the current UI, which is a help buffer.
  • Add a function for showing documentation. A worker pattern could be
    used when documentation is shown to support separate key bindings
    for showing documentation persistently and non-persistently.
  • Add a setting: does the user want to show documentation
    persistently? The wrapper for the previous function should use the
    value of this setting to specify the state of persistence.

Add an omnisharp-mode specific menu-bar enty

The menu should provide easy access to all of the plugin's functions
so that the user doesn't need to remember them all by heart.

So basically every function that is marked as (interactive) should be
found in that menu.

TODO specify exact menu layout

Create a minor mode for omnisharp-emacs

Currently omnisharp-emacs defines some stuff that may conflict with
settings or bindings in other modes. We should create a new minor mode
for omnisharp-emacs that has a mode-specific map. I propose the mode
be called omnisharp-mode for brevity.

There is also a suggestion for altering the loading of the
auto-complete company-mode integration here:

First pass of company-mode integration by bbbscarter
#17 (comment)

That should be treated as well.

One more thing: the example-config-for-evil-mode.el file should define
the mappings to be active only in omnisharp-mode

Organize source code into separate code files

Currently the source code is published in a single file. This is
cumbersome to navigate and in illogical order.

The file should be divided into separate files. Here is a suggestion:

A single file for common functions / utilities. Examples:

  • omnisharp--choose-quickfix-ido (navigate to a quickfix chosen
    via ido)
  • omnisharp--vector-to-list
  • omnisharp--get-common-params
  • omnisharp--get-max-item-length

A single code file per feature or logical group. Examples:

  • auto-complete
  • goto-definition
  • rename
  • solution-management
    • omnisharp-add-to-solution-current-file
    • omnisharp-add-to-solution-dired-selected-files
    • omnisharp-remove-from-project-current-file

Add error formats for detecting compilation errors

Currently, building a solution on both Unix and Windows systems will
produce the correct errors but it is not possible to navigate to
them (by clicking / by pressing enter).

This can easily be fixed with correct error-line-formats for both
systems. Here is an example I use for Linux in my personal config:

(add-to-list 'compilation-error-regexp-alist
             '(" in \\(.+\\):\\([0-9]+\\)" 1 2))

Error in parsing dummy file

I get the following error in console when running company-mode together with the omnisharp plugin. The error is from the omnisharpserver.exe:

****** Request ******
Loading dummy_file
Error parsing dummy_file:
[DomRegion FileName=, Begin=(15, 2), End=(-1, -1)] Identifier expected, `if' i
s a keyword
Getting Completion Data
Got Completion Data
****** Response ******
[]
/autocomplete 6ms

It seems that it connects fine, but cant parse what it gets. I run emacs and omnisharp on windows 7.

Add possibility to get raw command being sent to server for debugging

If we could get the raw (curl) command (or at least the data) that is being sent to the server when errors happen, we can more easily debug them.

We might be able to attach them as bug reports to the backend project as well.
Running the curl commands should provide an easy-to-test case for fixing server code.

end-of-file error when running omnisharp-navigate-to-current-type-member

Repro steps are as follows:

  • Find a file where the closing brace is on the last line in the file.
  • Go to that line.
  • Run omnisharp-navigate-to-current-type-member
  • Observe the error in the OmnisharpServer window
  • Workaround is to put a blank line after the closing brace

This is also happening when I'm using the new imenu stuff. I haven't managed to drill into what's going on yet, but at one point I was also getting an error that the line being request was one line beyond the length of the file, so it might be a (weird) out-by-one error somewhere.

Show all completions (overloads etc.) for symbol at point

Description: (point is at $)

User puts point on string.Fo$rmat(..) and invokes this feature's
command. A buffer pops up, showing all completions for
string.Format. In other cases completions for other members will
be shown, e.g. if the user had a FormatAndAddNewLine() extension
method, that would be shown as well.

Acceptance criteria:

  • option to select between showing frontends, with at least one default
  • a menu entry
  • default key binding for evil mode
  • optionally could be non-blocking (deferred.el ?)

Track OmniSharp versions for compatibility

This ticket mainly concerns OmniSharp development.

Newly developed features sometimes consist of changes to two projects:

  • OmniSharp, which omnisharp-emacs depends on
  • omnisharp-emacs itself

For a version of omnisharp-emacs to be valid it needs a specific
version of the OmniSharp backend - otherwise something might be broken.
For this reason it's beneficial to track OmniSharp versions along with
omnisharp-emacs versions.

This can be done by adding a git submodule in the repository root,
much like in the Vim binding here: https://github.com/nosami/Omnisharp .
Users / developers will not be forced to use the reference, but they
can use it to confirm they have the necessary version.

It will also help with installation. The typical user will want to
install the whole deal - since omnisharp-emacs is useless as a
frontend without the OmniSharp backend.

Building solution on Windows breaks on backslashes

This is the output from a single compilation:

-*- mode: compilation; default-directory: "c:/Projects/foo/" -*-
Compilation started at Tue Aug 13 11:22:35

C:\Windows\Microsoft.NET\Framework64\v4.0.30319\Msbuild.exe /m /nologo /v:q /property:GenerateFullPaths=true "c:/Projects/foo/foo.sln"
/bin/bash: C:WindowsMicrosoft.NETFramework64v4.0.30319Msbuild.exe: command not found

Add imenu support

It would be fabulous to have a way of listing, and jumping to, methods in the current file. imenu is the standard way of doing this, but even just ido-style completion and jumping would do.

Use customize-group interface in plugin customization

Emacs has a nice built-in customization interface called
customize-group. This draws nice widgets to the screen and lets the
user hide / show documentation when editing the package's
customization (and save settings, etc.).

This would be a good option for a customization interface.

Unable to handle some files on Windows

I have a long file at work that cannot be auto-completed.

Emacs responds with this error message:
apply: Spawning child process: exec format errorError during redisplay: (jit-lock-function 38625) signaled (wrong-type-argument stringp nil)

Truncating some lines from the end of the file enables this to work.

Will need to investigate further.

omnisharp-find-usages returns no results

I think I've fixed it on mine by changing find-usages to extract data from the 'QuickFixes json result, rather than the 'Usages ('Usages didn't exist in the data being returned on mine).

Let me know if I should check in my fix.

Add auto-complete source for /autocomplete API

Description:
The auto-complete source will offer semantic completions automatically
based on the output from OmniSharp's /autocomplete API. If none are
found, a new auto-complete source is picked and the completions for
that are returned.

Currently the auto-complete feature is called manually, and is
blocking.

Remarks:

  • check if the source is non-blocking. If it is, add an option
    (opt-out) about turning this on. If not, make the option opt-in.

Could also add a note like this in the documentation: when this is on,
no other sources will be used when this offers any results. This may
be confusing.

Add promo screenshots of features to landing page

Here is a list of things that probably look cool:

  • completion with popup
  • completion with ido
  • documentation with popup-tip. Add note that you don't
    have to use the tip but can use an ugly buffer instead.
  • find usages
  • go to type in current file
  • go to member in current type
  • rename. Show that it suggests the existing symbol name.
  • add/remove files to/from the solution in dired
  • overriding. Show suggestion list and result separately.
  • refactoring suggestions
  • solution building result in the compilation buffer
  • syntax errors found by flycheck

Add feature: run syntax check on save

When saving the current file, it would be nice to run a syntax check
on that file. The check could be ran either before saving or after
saving.

Add a setting omnisharp-run-syntax-check-on-save (default nil). Then
add a call to (omnisharp-syntax-check) to a hook that gets called when
the current is saved.

Latest version of Flycheck incompatible with Omnisharp checker

On loading Omnisharp with the latest version of Flychecker, I get the following backtrace:
error("Invalid command executable %S" (eval (let ((command-plist (omnisharp--get-curl-command (concat (omnisharp-get-host) "syntaxerrors") (omnisharp--get-common-params)))) (cons (plist-get command-plist :command) (plist-get command-plist :arguments))))) (flycheck-define-checker csharp-omnisharp-curl "A csharp source syntax checker using curl to call an OmniSharp\nserver process running in the background. Only checks the syntax - not\ntype errors." :command ((eval (let ((command-plist (omnisharp--get-curl-command (concat ... "syntaxerrors") (omnisharp--get-common-params)))) (cons (plist-get command-plist :command) (plist-get command-plist :arguments))))) :error-patterns ((error line-start (file-name) ":" line ":" column " " (message (one-or-more not-newline)))) :error-parser (lambda (output checker buffer) (omnisharp--flycheck-error-parser-raw-json output checker buffer)) :predicate (lambda nil t))
Digging into it a little, on the 21st November Flycheck changed the requirements of the executable argument to require plaintext as input:

flycheck/flycheck@8b61b9b

Add mock tests for all functionality

Currently we are missing tests. This is bad practice.
There are mock testing frameworks for emacs available
at MELPA. One should be picked and simple tests
devised for all functionality.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.