Use shutdown request to stop server

Use shutdown request to stop ycmd server in a portable way.
This commit is contained in:
micbou 2015-05-26 14:57:11 +02:00
parent c1047bee9a
commit 630b85ad01
2 changed files with 62 additions and 6 deletions

View File

@ -0,0 +1,54 @@
# Copyright (C) 2016 YouCompleteMe contributors
#
# 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/>.
from __future__ import unicode_literals
from __future__ import print_function
from __future__ import division
from __future__ import absolute_import
from future import standard_library
standard_library.install_aliases()
from builtins import * # noqa
from requests.exceptions import ReadTimeout
from ycm.client.base_request import BaseRequest
TIMEOUT_SECONDS = 0.1
class ShutdownRequest( BaseRequest ):
def __init__( self ):
super( BaseRequest, self ).__init__()
def Start( self ):
try:
self.PostDataToHandler( {},
'shutdown',
TIMEOUT_SECONDS )
except ReadTimeout:
pass
def Response( self ):
return self._response
def SendShutdownRequest():
request = ShutdownRequest()
# This is a blocking call.
request.Start()

View File

@ -49,6 +49,7 @@ from ycm.client.completion_request import ( CompletionRequest,
from ycm.client.omni_completion_request import OmniCompletionRequest from ycm.client.omni_completion_request import OmniCompletionRequest
from ycm.client.event_notification import ( SendEventNotificationAsync, from ycm.client.event_notification import ( SendEventNotificationAsync,
EventNotification ) EventNotification )
from ycm.client.shutdown_request import SendShutdownRequest
try: try:
from UltiSnips import UltiSnips_Manager from UltiSnips import UltiSnips_Manager
@ -107,6 +108,7 @@ DIAGNOSTIC_UI_FILETYPES = set( [ 'cpp', 'cs', 'c', 'objc', 'objcpp' ] )
class YouCompleteMe( object ): class YouCompleteMe( object ):
def __init__( self, user_options ): def __init__( self, user_options ):
self._available_completers = {}
self._user_options = user_options self._user_options = user_options
self._user_notified_about_crash = False self._user_notified_about_crash = False
self._diag_interface = DiagnosticInterface( user_options ) self._diag_interface = DiagnosticInterface( user_options )
@ -127,6 +129,7 @@ class YouCompleteMe( object ):
def _SetupServer( self ): def _SetupServer( self ):
self._available_completers = {} self._available_completers = {}
self._user_notified_about_crash = False
server_port = utils.GetUnusedLocalhostPort() server_port = utils.GetUnusedLocalhostPort()
# The temp options file is deleted by ycmd during startup # The temp options file is deleted by ycmd during startup
with NamedTemporaryFile( delete = False, mode = 'w+' ) as options_file: with NamedTemporaryFile( delete = False, mode = 'w+' ) as options_file:
@ -143,7 +146,7 @@ class YouCompleteMe( object ):
'--options_file={0}'.format( options_file.name ), '--options_file={0}'.format( options_file.name ),
'--log={0}'.format( self._user_options[ 'server_log_level' ] ), '--log={0}'.format( self._user_options[ 'server_log_level' ] ),
'--idle_suicide_seconds={0}'.format( '--idle_suicide_seconds={0}'.format(
SERVER_IDLE_SUICIDE_SECONDS )] SERVER_IDLE_SUICIDE_SECONDS ) ]
filename_format = os.path.join( utils.PathToCreatedTempDir(), filename_format = os.path.join( utils.PathToCreatedTempDir(),
'server_{port}_{std}.log' ) 'server_{port}_{std}.log' )
@ -206,16 +209,15 @@ class YouCompleteMe( object ):
return self._server_popen.pid return self._server_popen.pid
def _ServerCleanup( self ): def _ShutdownServer( self ):
if self.IsServerAlive(): if self.IsServerAlive():
self._server_popen.terminate() SendShutdownRequest()
def RestartServer( self ): def RestartServer( self ):
self._CloseLogs() self._CloseLogs()
vimsupport.PostVimMessage( 'Restarting ycmd server...' ) vimsupport.PostVimMessage( 'Restarting ycmd server...' )
self._user_notified_about_crash = False self._ShutdownServer()
self._ServerCleanup()
self._SetupServer() self._SetupServer()
@ -332,7 +334,7 @@ class YouCompleteMe( object ):
def OnVimLeave( self ): def OnVimLeave( self ):
self._ServerCleanup() self._ShutdownServer()
def OnCurrentIdentifierFinished( self ): def OnCurrentIdentifierFinished( self ):