2018-04-05 13:06:54 +02:00

63 lines
2.2 KiB
Python

# ============================================================================
# FILE: member.py
# AUTHOR: Shougo Matsushita <Shougo.Matsu at gmail.com>
# License: MIT license
# ============================================================================
from .base import Base
import re
from deoplete.util import (
get_buffer_config, convert2list,
parse_buffer_pattern, set_pattern, getlines)
class Source(Base):
def __init__(self, vim):
super().__init__(vim)
self.name = 'member'
self.mark = '[M]'
self.min_pattern_length = 0
self._object_pattern = r'[a-zA-Z_]\w*(?:\(\)?)?'
self._prefix = ''
self._prefix_patterns = {}
set_pattern(self._prefix_patterns,
'_', '\.')
set_pattern(self._prefix_patterns,
'c,objc', ['\.', '->'])
set_pattern(self._prefix_patterns,
'cpp,objcpp', ['\.', '->', '::'])
set_pattern(self._prefix_patterns,
'perl,php', ['->'])
set_pattern(self._prefix_patterns,
'ruby', ['\.', '::'])
set_pattern(self._prefix_patterns,
'lua', ['\.', ':'])
def get_complete_position(self, context):
# Check member prefix pattern.
for prefix_pattern in convert2list(
get_buffer_config(context, context['filetype'],
'deoplete_member_prefix_patterns',
'deoplete#member#prefix_patterns',
self._prefix_patterns)):
m = re.search(self._object_pattern + prefix_pattern + r'\w*$',
context['input'])
if m is None or prefix_pattern == '':
continue
self._prefix = re.sub(r'\w*$', '', m.group(0))
return re.search(r'\w*$', context['input']).start()
return -1
def gather_candidates(self, context):
return [{'word': x} for x in
parse_buffer_pattern(
getlines(self.vim),
r'(?<=' + re.escape(self._prefix) + r')\w+'
)
if x != context['complete_str']]