More lint warnings gone and simplified some code.

This commit is contained in:
Holger Rapp 2014-02-06 21:42:07 +01:00
parent dc00dd983d
commit fefef4e39f
7 changed files with 132 additions and 133 deletions

View File

@ -147,9 +147,10 @@ Following is the full stack trace:
return wrapper return wrapper
class SnippetManager(object): class SnippetManager(object):
"""The main entry point for all UltiSnips functionality. All Vim functions
call methods in this class."""
def __init__(self, expand_trigger, forward_trigger, backward_trigger): def __init__(self, expand_trigger, forward_trigger, backward_trigger):
"""The main entry point for all UltiSnips functionality. All Vim
functions call methods in this class."""
self.expand_trigger = expand_trigger self.expand_trigger = expand_trigger
self.forward_trigger = forward_trigger self.forward_trigger = forward_trigger
self.backward_trigger = backward_trigger self.backward_trigger = backward_trigger
@ -204,7 +205,7 @@ class SnippetManager(object):
def snippets_in_current_scope(self): def snippets_in_current_scope(self):
"""Returns the snippets that could be expanded to Vim as a global """Returns the snippets that could be expanded to Vim as a global
variable.""" variable."""
before, _ = _vim.buf.current_line_splitted before = _vim.buf.line_till_cursor
snippets = self._snips(before, True) snippets = self._snips(before, True)
# Sort snippets alphabetically # Sort snippets alphabetically
@ -231,7 +232,7 @@ class SnippetManager(object):
def list_snippets(self): def list_snippets(self):
"""Shows the snippets that could be expanded to the User and let her """Shows the snippets that could be expanded to the User and let her
select one.""" select one."""
before, after = _vim.buf.current_line_splitted before = _vim.buf.line_till_cursor
snippets = self._snips(before, True) snippets = self._snips(before, True)
if len(snippets) == 0: if len(snippets) == 0:
@ -248,7 +249,7 @@ class SnippetManager(object):
if not snippet: if not snippet:
return True return True
self._do_snippet(snippet, before, after) self._do_snippet(snippet, before)
return True return True
@ -285,47 +286,56 @@ class SnippetManager(object):
return self._snippets[ft] return self._snippets[ft]
@err_to_scratch_buffer @err_to_scratch_buffer
def add_snippet(self, trigger, value, descr, options, ft="all", globals=None, fn=None): def add_snippet(self, trigger, value, descr,
options, ft="all", globals=None, fn=None):
"""Add a snippet to the list of known snippets of the given 'ft'.""" """Add a snippet to the list of known snippets of the given 'ft'."""
l = self.snippet_dict(ft).add_snippet( self.snippet_dict(ft).add_snippet(
Snippet(trigger, value, descr, options, globals or {}), fn Snippet(trigger, value, descr, options, globals or {}), fn
) )
@err_to_scratch_buffer @err_to_scratch_buffer
def add_snippet_file(self, ft, path): def add_snippet_file(self, ft, path):
"""Add a file to be watched for changes to the 'ft' snippet dict."""
sd = self.snippet_dict(ft) sd = self.snippet_dict(ft)
sd.addfile(path) sd.addfile(path)
@err_to_scratch_buffer @err_to_scratch_buffer
def expand_anon(self, value, trigger="", descr="", options="", globals=None): def expand_anon(self, value, trigger="", descr="",
options="", globals=None):
"""Expand an anonymous snippet right here."""
if globals is None: if globals is None:
globals = {} globals = {}
before, after = _vim.buf.current_line_splitted before = _vim.buf.line_till_cursor
snip = Snippet(trigger, value, descr, options, globals) snip = Snippet(trigger, value, descr, options, globals)
if not trigger or snip.matches(before): if not trigger or snip.matches(before):
self._do_snippet(snip, before, after) self._do_snippet(snip, before)
return True return True
else: else:
return False return False
@err_to_scratch_buffer @err_to_scratch_buffer
def clear_snippets(self, triggers = [], ft = "all"): def clear_snippets(self, triggers=None, ft="all"):
"""Forget all snippets for the given 'ft'. If 'triggers' is given only
forget those with the given trigger."""
if triggers is None:
triggers = []
if ft in self._snippets: if ft in self._snippets:
self._snippets[ft].clear_snippets(triggers) self._snippets[ft].clear_snippets(triggers)
@err_to_scratch_buffer @err_to_scratch_buffer
def add_extending_info(self, ft, parents): def add_extending_info(self, ft, parents):
"""Add the list of 'parents' as being extended by the 'ft'."""
sd = self.snippet_dict(ft) sd = self.snippet_dict(ft)
for p in parents: for parent in parents:
if p in sd.extends: if parent in sd.extends:
continue continue
sd.extends.append(parent)
sd.extends.append(p)
@err_to_scratch_buffer @err_to_scratch_buffer
def cursor_moved(self): def cursor_moved(self):
"""Called whenever the cursor moved."""
self._vstate.remember_position() self._vstate.remember_position()
if _vim.eval("mode()") not in 'in': if _vim.eval("mode()") not in 'in':
return return
@ -336,7 +346,8 @@ class SnippetManager(object):
if self._csnippets: if self._csnippets:
cstart = self._csnippets[0].start.line cstart = self._csnippets[0].start.line
cend = self._csnippets[0].end.line + self._vstate.diff_in_buffer_length cend = self._csnippets[0].end.line + \
self._vstate.diff_in_buffer_length
ct = _vim.buf[cstart:cend + 1] ct = _vim.buf[cstart:cend + 1]
lt = self._vstate.remembered_buffer lt = self._vstate.remembered_buffer
pos = _vim.buf.cursor pos = _vim.buf.cursor
@ -349,7 +360,8 @@ class SnippetManager(object):
# remove all equal lines. Then do the same from the front. # remove all equal lines. Then do the same from the front.
if lt and ct: if lt and ct:
while (lt[lt_span[1]-1] == ct[ct_span[1]-1] and while (lt[lt_span[1]-1] == ct[ct_span[1]-1] and
self._vstate.ppos.line < initial_line + lt_span[1]-1 and pos.line < initial_line + ct_span[1]-1 and self._vstate.ppos.line < initial_line + lt_span[1]-1 and
pos.line < initial_line + ct_span[1]-1 and
(lt_span[0] < lt_span[1]) and (lt_span[0] < lt_span[1]) and
(ct_span[0] < ct_span[1])): (ct_span[0] < ct_span[1])):
ct_span[1] -= 1 ct_span[1] -= 1
@ -357,7 +369,8 @@ class SnippetManager(object):
while (lt_span[0] < lt_span[1] and while (lt_span[0] < lt_span[1] and
ct_span[0] < ct_span[1] and ct_span[0] < ct_span[1] and
lt[lt_span[0]] == ct[ct_span[0]] and lt[lt_span[0]] == ct[ct_span[0]] and
self._vstate.ppos.line >= initial_line and pos.line >= initial_line): self._vstate.ppos.line >= initial_line and
pos.line >= initial_line):
ct_span[0] += 1 ct_span[0] += 1
lt_span[0] += 1 lt_span[0] += 1
initial_line += 1 initial_line += 1
@ -376,7 +389,9 @@ class SnippetManager(object):
es = diff(lt, ct, initial_line) es = diff(lt, ct, initial_line)
self._csnippets[0].replay_user_edits(es) self._csnippets[0].replay_user_edits(es)
except IndexError: except IndexError:
pass # Rather do nothing than throwing an error. It will be correct most of the time # Rather do nothing than throwing an error. It will be correct
# most of the time
pass
self._check_if_still_inside_snippet() self._check_if_still_inside_snippet()
if self._csnippets: if self._csnippets:
@ -384,10 +399,8 @@ class SnippetManager(object):
self._vstate.remember_buffer(self._csnippets[0]) self._vstate.remember_buffer(self._csnippets[0])
def leaving_buffer(self): def leaving_buffer(self):
""" """Called when the user switches tabs/windows/buffers. It basically
Called when the user switches tabs/windows/buffers. It basically means means that all snippets must be properly terminated."""
that all snippets must be properly terminated
"""
while len(self._csnippets): while len(self._csnippets):
self._current_snippet_is_done() self._current_snippet_is_done()
self._reinit() self._reinit()
@ -397,6 +410,7 @@ class SnippetManager(object):
# Private/Protect Functions Below # # Private/Protect Functions Below #
################################### ###################################
def _error(self, msg): def _error(self, msg):
"""Shows 'msg' as error to the user."""
msg = _vim.escape("UltiSnips: " + msg) msg = _vim.escape("UltiSnips: " + msg)
if self._test_error: if self._test_error:
msg = msg.replace('"', r'\"') msg = msg.replace('"', r'\"')
@ -412,11 +426,12 @@ class SnippetManager(object):
_vim.command("echoerr %s" % msg) _vim.command("echoerr %s" % msg)
def _reinit(self): def _reinit(self):
"""Resets transient state."""
self._ctab = None self._ctab = None
self._ignore_movements = False self._ignore_movements = False
def _check_if_still_inside_snippet(self): def _check_if_still_inside_snippet(self):
# Did we leave the snippet with this movement? """Checks if the cursor is outside of the current snippet."""
if self._cs and ( if self._cs and (
not self._cs.start <= _vim.buf.cursor <= self._cs.end not self._cs.start <= _vim.buf.cursor <= self._cs.end
): ):
@ -425,23 +440,21 @@ class SnippetManager(object):
self._check_if_still_inside_snippet() self._check_if_still_inside_snippet()
def _current_snippet_is_done(self): def _current_snippet_is_done(self):
"""The current snippet should be terminated."""
self._csnippets.pop() self._csnippets.pop()
if not self._csnippets and _vim.eval("g:UltiSnipsClearJumpTrigger") != "0": if (not self._csnippets and
_vim.eval("g:UltiSnipsClearJumpTrigger") != "0"):
_vim.command("call UltiSnips_RestoreInnerKeys()") _vim.command("call UltiSnips_RestoreInnerKeys()")
def _jump(self, backwards=False): def _jump(self, backwards=False):
"""Helper method that does the actual jump."""
jumped = False jumped = False
if self._cs: if self._cs:
self._ctab = self._cs.select_next_tab(backwards) self._ctab = self._cs.select_next_tab(backwards)
if self._ctab: if self._ctab:
before, after = _vim.buf.current_line_splitted
if self._cs.snippet.has_option("s"): if self._cs.snippet.has_option("s"):
if after == "":
m = re.match(r'(.*?)\s+$', before)
if m:
lineno = _vim.buf.cursor.line lineno = _vim.buf.cursor.line
_vim.text_to_vim(Position(lineno, 0), Position( _vim.buf[lineno] = _vim.buf[lineno].rstrip()
lineno, len(before)+len(after)), m.group(1))
_vim.select(self._ctab.start, self._ctab.end) _vim.select(self._ctab.start, self._ctab.end)
jumped = True jumped = True
if self._ctab.no == 0: if self._ctab.no == 0:
@ -459,22 +472,22 @@ class SnippetManager(object):
return jumped return jumped
def _cache_unnamed_register(self): def _cache_unnamed_register(self):
"""Save the unnamed register."""
self._unnamed_reg_cached = True self._unnamed_reg_cached = True
unnamed_reg = _vim.eval('@"') unnamed_reg = _vim.eval('@"')
if self._last_placeholder != unnamed_reg: if self._last_placeholder != unnamed_reg:
self._unnamed_reg_cache = unnamed_reg self._unnamed_reg_cache = unnamed_reg
self._last_placeholder = self._ctab._initial_text self._last_placeholder = self._ctab.current_text
def restore_unnamed_register(self): def restore_unnamed_register(self):
"""Restores the unnamed register from the cache."""
if self._unnamed_reg_cached: if self._unnamed_reg_cached:
escaped_cache = self._unnamed_reg_cache.replace("'", "''") escaped_cache = self._unnamed_reg_cache.replace("'", "''")
_vim.command("let @\"='%s'" % escaped_cache) _vim.command("let @\"='%s'" % escaped_cache)
self._unnamed_register_cached = False self._unnamed_register_cached = False
def _handle_failure(self, trigger): def _handle_failure(self, trigger):
""" """Mainly make sure that we play well with SuperTab."""
Mainly make sure that we play well with SuperTab
"""
if trigger.lower() == "<tab>": if trigger.lower() == "<tab>":
feedkey = "\\" + trigger feedkey = "\\" + trigger
elif trigger.lower() == "<s-tab>": elif trigger.lower() == "<s-tab>":
@ -502,7 +515,8 @@ class SnippetManager(object):
# Use remap mode so SuperTab mappings will be invoked. # Use remap mode so SuperTab mappings will be invoked.
break break
if feedkey == r"\<Plug>SuperTabForward" or feedkey == r"\<Plug>SuperTabBackward": if (feedkey == r"\<Plug>SuperTabForward" or
feedkey == r"\<Plug>SuperTabBackward"):
_vim.command("return SuperTab(%s)" % _vim.escape(mode)) _vim.command("return SuperTab(%s)" % _vim.escape(mode))
elif feedkey: elif feedkey:
_vim.command("return %s" % _vim.escape(feedkey)) _vim.command("return %s" % _vim.escape(feedkey))
@ -522,22 +536,23 @@ class SnippetManager(object):
# Search if any of the snippets overwrites the previous # Search if any of the snippets overwrites the previous
# Dictionary allows O(1) access for easy overwrites # Dictionary allows O(1) access for easy overwrites
snippets = {} snippets = {}
for s in found_snippets: for snip in found_snippets:
if (s.trigger not in snippets) or s.overwrites_previous: if (snip.trigger not in snippets) or snip.overwrites_previous:
snippets[s.trigger] = [] snippets[snip.trigger] = []
snippets[s.trigger].append(s) snippets[snip.trigger].append(snip)
# Transform dictionary into flat list of snippets # Transform dictionary into flat list of snippets
selected_snippets = set([item for sublist in snippets.values() for item in sublist]) selected_snippets = set(
[item for sublist in snippets.values() for item in sublist])
# Return snippets to their original order # Return snippets to their original order
snippets = [snip for snip in found_snippets if snip in selected_snippets] snippets = [snip for snip in found_snippets if
snip in selected_snippets]
return snippets return snippets
def _do_snippet(self, snippet, before, after): def _do_snippet(self, snippet, before):
"""Expands the given snippet, and handles everything """Expands the given snippet, and handles everything
that needs to be done with it. that needs to be done with it."""
"""
if _vim.eval("g:UltiSnipsClearJumpTrigger") == "1": if _vim.eval("g:UltiSnipsClearJumpTrigger") == "1":
_vim.command("call UltiSnips_MapInnerKeys()") _vim.command("call UltiSnips_MapInnerKeys()")
# Adjust before, maybe the trigger is not the complete word # Adjust before, maybe the trigger is not the complete word
@ -577,7 +592,8 @@ class SnippetManager(object):
self._jump() self._jump()
def _try_expand(self): def _try_expand(self):
before, after = _vim.buf.current_line_splitted """Try to expand a snippet in the current place."""
before = _vim.buf.line_till_cursor
if not before: if not before:
return False return False
snippets = self._snips(before, False) snippets = self._snips(before, False)
@ -590,27 +606,28 @@ class SnippetManager(object):
snippet = _ask_snippets(snippets) snippet = _ask_snippets(snippets)
if not snippet: if not snippet:
return True return True
self._do_snippet(snippet, before, after) self._do_snippet(snippet, before)
return True return True
@property @property
def _cs(self): def _cs(self):
"""The current snippet or None."""
if not len(self._csnippets): if not len(self._csnippets):
return None return None
return self._csnippets[-1] return self._csnippets[-1]
def _parse_snippets(self, ft, fn, file_data=None): def _parse_snippets(self, ft, filename, file_data=None):
self.add_snippet_file(ft, fn) """Parse the file 'filename' for the given 'ft'."""
SnippetsFileParser(ft, fn, self, file_data).parse() self.add_snippet_file(ft, filename)
SnippetsFileParser(ft, filename, self, file_data).parse()
@property @property
def primary_filetype(self): def primary_filetype(self):
"""This filetype will be edited when UltiSnipsEdit is called without """This filetype will be edited when UltiSnipsEdit is called without
any arguments. any arguments."""
"""
return self._filetypes[_vim.buf.nr][0] return self._filetypes[_vim.buf.nr][0]
def file_to_edit(self, ft): def file_to_edit(self, ft): # pylint: disable=no-self-use
""" Gets a file to edit based on the given filetype. """ Gets a file to edit based on the given filetype.
If no filetype is given, uses the current filetype from Vim. If no filetype is given, uses the current filetype from Vim.
@ -650,6 +667,7 @@ class SnippetManager(object):
return edit return edit
def _load_snippets_for(self, ft): def _load_snippets_for(self, ft):
"""Load all snippets for the given 'ft'."""
self.snippet_dict(ft).reset() self.snippet_dict(ft).reset()
for fn in _base_snippet_files_for(ft): for fn in _base_snippet_files_for(ft):
self._parse_snippets(ft, fn) self._parse_snippets(ft, fn)
@ -659,6 +677,8 @@ class SnippetManager(object):
self._load_snippets_for(parent_ft) self._load_snippets_for(parent_ft)
def _needs_update(self, ft): def _needs_update(self, ft):
"""Returns true if any files for 'ft' have changed and must be
reloaded."""
do_hash = _vim.eval('exists("g:UltiSnipsDoHash")') == "0" \ do_hash = _vim.eval('exists("g:UltiSnipsDoHash")') == "0" \
or _vim.eval("g:UltiSnipsDoHash") != "0" or _vim.eval("g:UltiSnipsDoHash") != "0"
@ -674,6 +694,8 @@ class SnippetManager(object):
return False return False
def _ensure_loaded(self, ft, checked=None): def _ensure_loaded(self, ft, checked=None):
"""Make sure that the snippets for 'ft' and everything it extends are
loaded."""
if not checked: if not checked:
checked = set([ft]) checked = set([ft])
elif ft in checked: elif ft in checked:
@ -688,22 +710,24 @@ class SnippetManager(object):
self._ensure_loaded(parent, checked) self._ensure_loaded(parent, checked)
def _ensure_all_loaded(self): def _ensure_all_loaded(self):
"""Make sure that all filetypes fur the current buffer are loaded."""
for ft in self._filetypes[_vim.buf.nr]: for ft in self._filetypes[_vim.buf.nr]:
self._ensure_loaded(ft) self._ensure_loaded(ft)
def reset_buffer_filetypes(self): def reset_buffer_filetypes(self):
"""Reset the filetypes for the current buffer."""
if _vim.buf.nr in self._filetypes: if _vim.buf.nr in self._filetypes:
del self._filetypes[_vim.buf.nr] del self._filetypes[_vim.buf.nr]
def add_buffer_filetypes(self, ft): def add_buffer_filetypes(self, ft):
""" Checks for changes in the list of snippet files or the contents """Checks for changes in the list of snippet files or the contents of
of the snippet files and reloads them if necessary. the snippet files and reloads them if necessary. """
"""
buf_fts = self._filetypes[_vim.buf.nr] buf_fts = self._filetypes[_vim.buf.nr]
idx = -1 idx = -1
for ft in ft.split("."): for ft in ft.split("."):
ft = ft.strip() ft = ft.strip()
if not ft: continue if not ft:
continue
try: try:
idx = buf_fts.index(ft) idx = buf_fts.index(ft)
except ValueError: except ValueError:
@ -712,8 +736,7 @@ class SnippetManager(object):
self._ensure_all_loaded() self._ensure_all_loaded()
def _find_snippets(self, ft, trigger, potentially=False, seen=None): def _find_snippets(self, ft, trigger, potentially=False, seen=None):
""" """Find snippets matching trigger
Find snippets matching trigger
ft - file type to search ft - file type to search
trigger - trigger to match against trigger - trigger to match against

View File

@ -34,14 +34,13 @@ class VimBuffer(object):
return len(vim.current.buffer) return len(vim.current.buffer)
@property @property
def current_line_splitted(self): def line_till_cursor(self):
"""Returns the text before and after the cursor as a tuple.""" """Returns the text before the cursor."""
# Note: we want byte position here # Note: we want byte position here
lineno, col = vim.current.window.cursor _, col = vim.current.window.cursor
line = vim.current.line line = vim.current.line
before, after = as_unicode(line[:col]), as_unicode(line[col:]) before = as_unicode(line[:col])
return before, after return before
@property @property
def nr(self): def nr(self):

View File

@ -8,26 +8,24 @@ as many python versions as possible.
import sys import sys
import vim import vim # pylint:disable=import-error
__all__ = ['as_unicode', 'compatible_exec', 'vim_cursor', 'set_vim_cursor'] def _vim_dec(string):
"""Decode 'string' using &encoding."""
def _vim_dec(s):
try: try:
return s.decode(vim.eval("&encoding")) return string.decode(vim.eval("&encoding"))
except UnicodeDecodeError: except UnicodeDecodeError:
# At least we tried. There might be some problems down the road now # At least we tried. There might be some problems down the road now
return s return string
def _vim_enc(s): def _vim_enc(string):
"""Encode 'string' using &encoding."""
try: try:
return s.encode(vim.eval("&encoding")) return string.encode(vim.eval("&encoding"))
except UnicodeEncodeError: except UnicodeEncodeError:
return s return string
if sys.version_info >= (3, 0): if sys.version_info >= (3, 0):
from UltiSnips.compatibility_py3 import *
def col2byte(line, col): def col2byte(line, col):
""" """
Convert a valid column index into a byte index inside Convert a valid column index into a byte index inside
@ -45,16 +43,16 @@ if sys.version_info >= (3,0):
raw_bytes = _vim_enc(line)[:nbyte] raw_bytes = _vim_enc(line)[:nbyte]
return len(_vim_dec(raw_bytes)) return len(_vim_dec(raw_bytes))
def as_unicode(s): def as_unicode(string):
if isinstance(s, bytes): """Return 'string' as unicode instance."""
return _vim_dec(s) if isinstance(string, bytes):
return str(s) return _vim_dec(string)
return str(string)
def as_vimencoding(s): def as_vimencoding(string):
return s """Return 'string' as Vim internal encoding."""
return string
else: else:
from UltiSnips.compatibility_py2 import *
import warnings import warnings
warnings.filterwarnings("ignore", category=DeprecationWarning) warnings.filterwarnings("ignore", category=DeprecationWarning)
@ -76,10 +74,12 @@ else:
return nbyte return nbyte
return len(_vim_dec(line[:nbyte])) return len(_vim_dec(line[:nbyte]))
def as_unicode(s): def as_unicode(string):
if isinstance(s, str): """Return 'string' as unicode instance."""
return _vim_dec(s) if isinstance(string, str):
return unicode(s) return _vim_dec(string)
return unicode(string)
def as_vimencoding(s): def as_vimencoding(string):
return _vim_enc(s) """Return 'string' as unicode instance."""
return _vim_enc(string)

View File

@ -1,18 +0,0 @@
#!/usr/bin/env python
# encoding: utf-8
"""
This file contains code that is invalid in python3 and must therefore never be
seen by the interpretor
"""
def compatible_exec(code, gglobals = None, glocals = None):
if gglobals is not None and glocals is not None:
exec code in gglobals, glocals
elif gglobals is not None:
exec code in gglobals
else:
exec code

View File

@ -1,9 +0,0 @@
#!/usr/bin/env python
# encoding: utf-8
"""
This file contains code that is invalid in python2 and must therefore never be
seen by the interpretor
"""
compatible_exec = exec

View File

@ -5,7 +5,7 @@ import os
from collections import namedtuple from collections import namedtuple
import UltiSnips._vim as _vim import UltiSnips._vim as _vim
from UltiSnips.compatibility import compatible_exec, as_unicode from UltiSnips.compatibility import as_unicode
from UltiSnips.indent_util import IndentUtil from UltiSnips.indent_util import IndentUtil
from UltiSnips.text_objects._base import NoneditableTextObject from UltiSnips.text_objects._base import NoneditableTextObject
@ -187,7 +187,7 @@ class PythonCode(NoneditableTextObject):
self._globals = {} self._globals = {}
globals = snippet.globals.get("!p", []) globals = snippet.globals.get("!p", [])
compatible_exec("\n".join(globals).replace("\r\n", "\n"), self._globals) exec("\n".join(globals).replace("\r\n", "\n"), self._globals)
# Add Some convenience to the code # Add Some convenience to the code
self._code = "import re, os, vim, string, random\n" + code self._code = "import re, os, vim, string, random\n" + code
@ -213,7 +213,7 @@ class PythonCode(NoneditableTextObject):
'snip': self._snip, 'snip': self._snip,
}) })
compatible_exec(self._code, self._globals, local_d) exec(self._code, self._globals, local_d)
rv = as_unicode( rv = as_unicode(
self._snip.rv if self._snip._rv_changed self._snip.rv if self._snip._rv_changed

View File

@ -34,9 +34,13 @@ load-plugins=
# --enable=similarities". If you want to run only the classes checker, but have # --enable=similarities". If you want to run only the classes checker, but have
# no Warning level messages displayed, use"--disable=all --enable=classes # no Warning level messages displayed, use"--disable=all --enable=classes
# --disable=W" # --disable=W"
disable=too-many-public-methods, disable=
attribute-defined-outside-init,
fixme,
redefined-builtin,
too-many-arguments,
too-many-instance-attributes, too-many-instance-attributes,
attribute-defined-outside-init too-many-public-methods,
[REPORTS] [REPORTS]