YouCompleteMe/python/ycm/completers/cs/cs_completer.py

115 lines
3.5 KiB
Python
Raw Normal View History

#!/usr/bin/env python
#
# Copyright (C) 2011, 2012 Chiel ten Brinke <ctenbrinke@gmail.com>
# Strahinja Val Markovic <val@markovic.io>
#
# This file is part of YouCompleteMe.
#
# YouCompleteMe is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# YouCompleteMe is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with YouCompleteMe. If not, see <http://www.gnu.org/licenses/>.
import vim
2013-06-21 16:26:11 -04:00
import os
import glob
from ycm.completers.threaded_completer import ThreadedCompleter
from ycm import vimsupport
import urllib2
import urllib
import urlparse
import json
class CsharpCompleter( ThreadedCompleter ):
"""
A Completer that uses the Omnisharp server as completion engine.
"""
def __init__( self ):
super( CsharpCompleter, self ).__init__()
2013-06-13 17:34:34 -04:00
self.OmniSharp_host = 2000
self._StartServer()
def SupportedFiletypes( self ):
""" Just csharp """
return ['cs']
def ComputeCandidates( self, unused_query, unused_start_column ):
return [ { 'word': str( completion['CompletionText'] ),
2013-06-07 05:45:36 -04:00
'menu': str( completion['DisplayText'] ),
'info': str( completion['Description'] ) }
2013-06-13 17:34:34 -04:00
for completion in self._GetCompletions() ]
2013-06-13 17:34:34 -04:00
def DefinedSubcommands( self ):
return [ "StartServer",
"StopServer" ]
def OnUserCommand( self, arguments ):
if not arguments:
self.EchoUserCommandsHelpMessage()
return
command = arguments[ 0 ]
if command == 'StartServer':
self._StartServer()
elif command == 'StopServer':
self._StopServer()
def _StartServer( self ):
""" Start the OmniSharp server """
if ( not self._ServerIsRunning() ):
# Find the solution file
2013-06-21 16:26:11 -04:00
folder = os.path.dirname( vim.current.buffer.name )
solutionfiles = glob.glob1( folder, "*.sln" )
while not solutionfiles:
lastfolder = folder
# Traverse up a level
folder = os.path.dirname( folder )
if folder == lastfolder:
break
solutionfiles = glob.glob1( folder, "*.sln" )
if len( solutionfiles ) == 1:
pass # start server here
else:
pass # some other stuff, like notifying
2013-06-13 17:34:34 -04:00
def _StopServer( self ):
""" Stop the OmniSharp server """
if ( self._ServerIsRunning() ):
self._GetResponse( "/stopserver" )
def _ServerIsRunning( self ):
""" Check if the OmniSharp server is running """
2013-06-21 16:26:11 -04:00
return False
2013-06-13 17:34:34 -04:00
def _GetCompletions( self ):
""" Ask server for completions """
line, column = vimsupport.CurrentLineAndColumn()
parameters = {}
parameters['line'], parameters['column'] = line + 1, column + 1
parameters['buffer'] = '\n'.join( vim.current.buffer )
parameters['filename'] = vim.current.buffer.name
2013-06-13 17:34:34 -04:00
return self._GetResponse( '/autocomplete', parameters ) | []
2013-06-13 17:34:34 -04:00
def _GetResponse( self, endPoint, parameters={} ):
""" Handle communication with server """
2013-06-09 05:22:11 -04:00
target = urlparse.urljoin( self.OmniSharp_host , endPoint )
parameters = urllib.urlencode( parameters )
try:
response = urllib2.urlopen( target, parameters )
2013-06-13 17:34:34 -04:00
return json.loads( response.read() )
except:
2013-06-13 17:34:34 -04:00
return None