Home | History | Annotate | Download | only in apitools
      1 # PyLint config for apitools code.
      2 #
      3 # NOTES:
      4 #
      5 # - Rules for test / demo code are generated into 'pylintrc_reduced'
      6 #   as deltas from this configuration by the 'run_pylint.py' script.
      7 #
      8 # - 'RATIONALE:  API mapping' as a defense for non-default settings is
      9 #   based on the fact that this library maps APIs which are outside our
     10 #   control, and adhering to the out-of-the-box defaults would induce
     11 #   breakage / complexity in those mappings
     12 #
     13 [MASTER]
     14 
     15 # Specify a configuration file.
     16 # DEFAULT:  rcfile=
     17 
     18 # Python code to execute, usually for sys.path manipulation such as
     19 # pygtk.require().
     20 # DEFAULT: init-hook=
     21 
     22 # Profiled execution.
     23 # DEFAULT:  profile=no
     24 
     25 # Add files or directories to the blacklist. They should be base names, not
     26 # paths.
     27 # DEFAULT:  ignore=CVS
     28 # NOTE: This path must be relative due to the use of
     29 #       os.walk in astroid.modutils.get_module_files.
     30 
     31 # Pickle collected data for later comparisons.
     32 # DEFAULT:  persistent=yes
     33 
     34 # List of plugins (as comma separated values of python modules names) to load,
     35 # usually to register additional checkers.
     36 # DEFAULT:  load-plugins=
     37 
     38 # DEPRECATED
     39 # DEFAULT:  include-ids=no
     40 
     41 # DEPRECATED
     42 # DEFAULT:  symbols=no
     43 
     44 
     45 [MESSAGES CONTROL]
     46 
     47 # TODO: remove cyclic-import.
     48 disable =
     49     cyclic-import,
     50     fixme,
     51     import-error,
     52     locally-disabled,
     53     locally-enabled,
     54     no-member,
     55     no-name-in-module,
     56     no-self-use,
     57     super-on-old-class,
     58     too-many-arguments,
     59     too-many-function-args,
     60 
     61 
     62 [REPORTS]
     63 
     64 # Set the output format. Available formats are text, parseable, colorized, msvs
     65 # (visual studio) and html. You can also give a reporter class, eg
     66 # mypackage.mymodule.MyReporterClass.
     67 # DEFAULT:  output-format=text
     68 
     69 # Put messages in a separate file for each module / package specified on the
     70 # command line instead of printing them on stdout. Reports (if any) will be
     71 # written in a file name "pylint_global.[txt|html]".
     72 # DEFAULT:  files-output=no
     73 
     74 # Tells whether to display a full report or only the messages
     75 # DEFAULT:  reports=yes
     76 # RATIONALE:  run from Travis / tox, and don't need / want to parse output.
     77 reports=no
     78 
     79 # Python expression which should return a note less than 10 (10 is the highest
     80 # note). You have access to the variables errors warning, statement which
     81 # respectively contain the number of errors / warnings messages and the total
     82 # number of statements analyzed. This is used by the global evaluation report
     83 # (RP0004).
     84 # DEFAULT:  evaluation=10.0 - ((float(5 * error + warning + refactor + convention) / statement) * 10)
     85 
     86 # Add a comment according to your evaluation note. This is used by the global
     87 # evaluation report (RP0004).
     88 # DEFAULT:  comment=no
     89 
     90 # Template used to display messages. This is a python new-style format string
     91 # used to format the message information. See doc for all details
     92 #msg-template=
     93 
     94 
     95 [SIMILARITIES]
     96 
     97 # Minimum lines number of a similarity.
     98 # DEFAULT:  min-similarity-lines=4
     99 min-similarity-lines=15
    100 
    101 # Ignore comments when computing similarities.
    102 # DEFAULT:  ignore-comments=yes
    103 
    104 # Ignore docstrings when computing similarities.
    105 # DEFAULT:  ignore-docstrings=yes
    106 
    107 # Ignore imports when computing similarities.
    108 # DEFAULT:  ignore-imports=no
    109 ignore-imports=yes
    110 
    111 
    112 [VARIABLES]
    113 
    114 # Tells whether we should check for unused import in __init__ files.
    115 # DEFAULT:  init-import=no
    116 
    117 # A regular expression matching the name of dummy variables (i.e. expectedly
    118 # not used).
    119 dummy-variables-rgx=^\*{0,2}(_$|unused_|dummy_)
    120 
    121 
    122 # List of additional names supposed to be defined in builtins. Remember that
    123 # you should avoid to define new builtins when possible.
    124 # DEFAULT:  additional-builtins=
    125 
    126 
    127 [LOGGING]
    128 
    129 # Logging modules to check that the string format arguments are in logging
    130 # function parameter format
    131 # DEFAULT:  logging-modules=logging
    132 
    133 
    134 [FORMAT]
    135 
    136 # Maximum number of characters on a single line.
    137 # DEFAULT:  max-line-length=80
    138 
    139 # Regexp for a line that is allowed to be longer than the limit.
    140 # DEFAULT:  ignore-long-lines=^\s*(# )?<?https?://\S+>?$
    141 
    142 # Allow the body of an if to be on the same line as the test if there is no
    143 # else.
    144 # DEFAULT:  single-line-if-stmt=no
    145 
    146 # List of optional constructs for which whitespace checking is disabled
    147 # DEFAULT:  no-space-check=trailing-comma,dict-separator
    148 # RATIONALE: pylint ignores whitespace checks around the
    149 #            constructs "dict-separator" (cases like {1:2}) and
    150 #            "trailing-comma" (cases like {1: 2, }).
    151 #            By setting "no-space-check" to empty whitespace checks will be
    152 #            enforced around both constructs.
    153 no-space-check =
    154 
    155 # Maximum number of lines in a module
    156 # DEFAULT:  max-module-lines=1000
    157 max-module-lines=1500
    158 
    159 # String used as indentation unit. This is usually " " (4 spaces) or "\t" (1
    160 # tab).
    161 # DEFAULT:  indent-string='    '
    162 
    163 # Number of spaces of indent required inside a hanging or continued line.
    164 # DEFAULT:  indent-after-paren=4
    165 
    166 
    167 [MISCELLANEOUS]
    168 
    169 # List of note tags to take in consideration, separated by a comma.
    170 # DEFAULT:  notes=FIXME,XXX,TODO
    171 
    172 
    173 [BASIC]
    174 
    175 # Regular expression which should only match function or class names that do
    176 # not require a docstring.
    177 # DEFAULT:  no-docstring-rgx=__.*__
    178 no-docstring-rgx=(__.*__|main)
    179 
    180 # Minimum line length for functions/classes that require docstrings, shorter
    181 # ones are exempt.
    182 # DEFAULT:  docstring-min-length=-1
    183 docstring-min-length=10
    184 
    185 # Regular expression which should only match correct module names. The
    186 # leading underscore is sanctioned for private modules by Google's style
    187 # guide.
    188 module-rgx=^(_?[a-z][a-z0-9_]*)|__init__$
    189 
    190 # Regular expression matching correct constant names
    191 # DEFAULT:  const-rgx=(([A-Z_][A-Z0-9_]*)|(__.*__))$
    192 const-rgx=^(_?[A-Z][A-Z0-9_]*|__[a-z0-9_]+__|_?[a-z][a-z0-9_]*)$
    193 
    194 # Regular expression matching correct class attribute names
    195 # DEFAULT:  class-attribute-rgx=([A-Za-z_][A-Za-z0-9_]{2,30}|(__.*__))$
    196 class-attribute-rgx=^(_?[A-Z][A-Z0-9_]*|__[a-z0-9_]+__|_?[a-z][a-z0-9_]*)$
    197 
    198 # Regular expression matching correct class names
    199 # DEFAULT:  class-rgx=[A-Z_][a-zA-Z0-9]+$
    200 class-rgx=^_?[A-Z][a-zA-Z0-9]*$
    201 
    202 # Regular expression which should only match correct function names.
    203 # 'camel_case' and 'snake_case' group names are used for consistency of naming
    204 # styles across functions and methods.
    205 function-rgx=^(?:(?P<camel_case>_?[A-Z][a-zA-Z0-9]*)|(?P<snake_case>_?[a-z][a-z0-9_]*))$
    206 
    207 # Regular expression which should only match correct method names.
    208 # 'camel_case' and 'snake_case' group names are used for consistency of naming
    209 # styles across functions and methods. 'exempt' indicates a name which is
    210 # consistent with all naming styles.
    211 method-rgx=^(?:(?P<exempt>__[a-z0-9_]+__|next)|(?P<camel_case>_{0,2}[A-Z][a-zA-Z0-9]*)|(?P<snake_case>_{0,2}[a-z][a-z0-9_]*))$
    212 
    213 # Regular expression matching correct attribute names
    214 # DEFAULT:  attr-rgx=[a-z_][a-z0-9_]{2,30}$
    215 attr-rgx=^_{0,2}[a-z][a-z0-9_]*$
    216 
    217 # Regular expression matching correct argument names
    218 # DEFAULT:  argument-rgx=[a-z_][a-z0-9_]{2,30}$
    219 argument-rgx=^[a-z][a-z0-9_]*$
    220 
    221 # Regular expression matching correct variable names
    222 # DEFAULT:  variable-rgx=[a-z_][a-z0-9_]{2,30}$
    223 variable-rgx=^[a-z][a-z0-9_]*$
    224 
    225 # Regular expression matching correct inline iteration names
    226 # DEFAULT:  inlinevar-rgx=[A-Za-z_][A-Za-z0-9_]*$
    227 inlinevar-rgx=^[a-z][a-z0-9_]*$
    228 
    229 # Good variable names which should always be accepted, separated by a comma
    230 # DEFAULT:  good-names=i,j,k,ex,Run,_
    231 good-names=main,_
    232 
    233 # Bad variable names which should always be refused, separated by a comma
    234 # DEFAULT:  bad-names=foo,bar,baz,toto,tutu,tata
    235 bad-names=
    236 
    237 # List of builtins function names that should not be used, separated by a comma
    238 # <http://go/python-style#Deprecated_Language_Features>
    239 bad-functions=input,apply,reduce
    240 
    241 
    242 [TYPECHECK]
    243 
    244 # Tells whether missing members accessed in mixin class should be ignored. A
    245 # mixin class is detected if its name ends with "mixin" (case insensitive).
    246 # DEFAULT:  ignore-mixin-members=yes
    247 
    248 # List of module names for which member attributes should not be checked
    249 # (useful for modules/projects where namespaces are manipulated during runtime
    250 # and thus existing member attributes cannot be deduced by static analysis
    251 # DEFAULT:  ignored-modules=
    252 
    253 # List of classes names for which member attributes should not be checked
    254 # (useful for classes with attributes dynamically set).
    255 # DEFAULT:  ignored-classes=SQLObject
    256 
    257 # When zope mode is activated, add a predefined set of Zope acquired attributes
    258 # to generated-members.
    259 # DEFAULT:  zope=no
    260 
    261 # List of members which are set dynamically and missed by pylint inference
    262 # system, and so shouldn't trigger E0201 when accessed. Python regular
    263 # expressions are accepted.
    264 # DEFAULT:  generated-members=REQUEST,acl_users,aq_parent
    265 
    266 
    267 [IMPORTS]
    268 
    269 # Deprecated modules which should not be used, separated by a comma
    270 # DEFAULT:  deprecated-modules=regsub,TERMIOS,Bastion,rexec
    271 
    272 # Create a graph of every (i.e. internal and external) dependencies in the
    273 # given file (report RP0402 must not be disabled)
    274 # DEFAULT:  import-graph=
    275 
    276 # Create a graph of external dependencies in the given file (report RP0402 must
    277 # not be disabled)
    278 # DEFAULT:  ext-import-graph=
    279 
    280 # Create a graph of internal dependencies in the given file (report RP0402 must
    281 # not be disabled)
    282 # DEFAULT:  int-import-graph=
    283 
    284 
    285 [CLASSES]
    286 
    287 # List of interface methods to ignore, separated by a comma. This is used for
    288 # instance to not check methods defines in Zope's Interface base class.
    289 # DEFAULT:  ignore-iface-methods=isImplementedBy,deferred,extends,names,namesAndDescriptions,queryDescriptionFor,getBases,getDescriptionFor,getDoc,getName,getTaggedValue,getTaggedValueTags,isEqualOrExtendedBy,setTaggedValue,isImplementedByInstancesOf,adaptWith,is_implemented_by
    290 
    291 # List of method names used to declare (i.e. assign) instance attributes.
    292 # DEFAULT:  defining-attr-methods=__init__,__new__,setUp
    293 
    294 # List of valid names for the first argument in a class method.
    295 # DEFAULT:  valid-classmethod-first-arg=cls
    296 
    297 # List of valid names for the first argument in a metaclass class method.
    298 # DEFAULT:  valid-metaclass-classmethod-first-arg=mcs
    299 
    300 
    301 [DESIGN]
    302 
    303 # Maximum number of arguments for function / method
    304 # DEFAULT:  max-args=5
    305 # RATIONALE:  API-mapping
    306 max-args = 14
    307 
    308 # Argument names that match this expression will be ignored. Default to name
    309 # with leading underscore
    310 # DEFAULT:  ignored-argument-names=_.*
    311 
    312 # Maximum number of locals for function / method body
    313 # DEFAULT:  max-locals=15
    314 max-locals=24
    315 
    316 # Maximum number of return / yield for function / method body
    317 # DEFAULT:  max-returns=6
    318 max-returns=9
    319 
    320 # Maximum number of branch for function / method body
    321 # DEFAULT:  max-branches=12
    322 max-branches=21
    323 
    324 # Maximum number of statements in function / method body
    325 # DEFAULT:  max-statements=50
    326 
    327 # Maximum number of parents for a class (see R0901).
    328 # DEFAULT:  max-parents=7
    329 
    330 # Maximum number of attributes for a class (see R0902).
    331 # DEFAULT:  max-attributes=7
    332 # RATIONALE:  API mapping
    333 max-attributes=19
    334 
    335 # Minimum number of public methods for a class (see R0903).
    336 # DEFAULT:  min-public-methods=2
    337 # RATIONALE:  context mgrs may have *no* public methods
    338 min-public-methods=0
    339 
    340 # Maximum number of public methods for a class (see R0904).
    341 # DEFAULT:  max-public-methods=20
    342 # RATIONALE:  API mapping
    343 max-public-methods=40
    344 
    345 [ELIF]
    346 max-nested-blocks=6
    347 
    348 [EXCEPTIONS]
    349 
    350 # Exceptions that will emit a warning when being caught. Defaults to
    351 # "Exception"
    352 # DEFAULT:  overgeneral-exceptions=Exception
    353