bee_python 0.0.3 → 0.0.4
Sign up to get free protection for your applications and to get access to all the features.
- data/{build/README → README} +1 -1
- data/egg/egg/build.yml +11 -49
- data/egg/egg.yml +19 -27
- data/egg/http/build.erb +32 -36
- data/egg/http/libhttp.py +102 -0
- data/egg/http/pylint.cfg +236 -0
- data/egg/http/server.py +7 -0
- data/egg/http/test.erb +32 -0
- data/egg/http.yml +33 -29
- data/egg/mysql/mysql.py +8 -9
- data/egg/project/build.erb +21 -53
- data/egg/project/pylint.cfg +236 -0
- data/egg/project/test.py +2 -2
- data/egg/project.yml +23 -31
- data/egg/script/build.erb +18 -23
- data/egg/script/pylint.cfg +236 -0
- data/egg/script.yml +22 -18
- data/egg/source/source.py +6 -6
- data/egg/test/test.py +1 -1
- data/lib/bee_task_python.rb +3 -34
- data/python.yml +123 -0
- metadata +61 -503
- data/test/build.yml +0 -16
- data/test/tc_bee_task_python.rb +0 -27
- data/test/test_build.rb +0 -26
- data/test/test_build_listener.rb +0 -110
- data/test/ts_bee_python.rb +0 -26
- data/tools/common/__init__.py +0 -5
- data/tools/common/common/__init__.py +0 -140
- data/tools/common/common/__pkginfo__.py +0 -43
- data/tools/common/common/adbh.py +0 -35
- data/tools/common/common/cache.py +0 -114
- data/tools/common/common/changelog.py +0 -234
- data/tools/common/common/clcommands.py +0 -181
- data/tools/common/common/cli.py +0 -212
- data/tools/common/common/compat.py +0 -328
- data/tools/common/common/configuration.py +0 -1087
- data/tools/common/common/contexts.py +0 -58
- data/tools/common/common/corbautils.py +0 -117
- data/tools/common/common/daemon.py +0 -171
- data/tools/common/common/date.py +0 -279
- data/tools/common/common/db.py +0 -49
- data/tools/common/common/dbf.py +0 -229
- data/tools/common/common/debugger.py +0 -208
- data/tools/common/common/decorators.py +0 -190
- data/tools/common/common/deprecation.py +0 -118
- data/tools/common/common/fileutils.py +0 -409
- data/tools/common/common/graph.py +0 -259
- data/tools/common/common/html.py +0 -142
- data/tools/common/common/interface.py +0 -76
- data/tools/common/common/logging_ext.py +0 -166
- data/tools/common/common/modutils.py +0 -670
- data/tools/common/common/optik_ext.py +0 -383
- data/tools/common/common/optparser.py +0 -92
- data/tools/common/common/pdf_ext.py +0 -111
- data/tools/common/common/proc.py +0 -276
- data/tools/common/common/pyro_ext.py +0 -146
- data/tools/common/common/pytest.py +0 -754
- data/tools/common/common/shellutils.py +0 -383
- data/tools/common/common/sphinx_ext.py +0 -87
- data/tools/common/common/sphinxutils.py +0 -122
- data/tools/common/common/sqlgen.py +0 -31
- data/tools/common/common/table.py +0 -930
- data/tools/common/common/tasksqueue.py +0 -97
- data/tools/common/common/test/__init__.py +0 -1
- data/tools/common/common/test/data/ChangeLog +0 -184
- data/tools/common/common/test/data/MyPyPa-0.1.0-py2.5.egg +0 -0
- data/tools/common/common/test/data/__init__.py +0 -1
- data/tools/common/common/test/data/content_differ_dir/NOTHING +0 -0
- data/tools/common/common/test/data/content_differ_dir/README +0 -1
- data/tools/common/common/test/data/content_differ_dir/subdir/coin +0 -1
- data/tools/common/common/test/data/content_differ_dir/subdir/toto.txt +0 -53
- data/tools/common/common/test/data/file_differ_dir/NOTHING +0 -0
- data/tools/common/common/test/data/file_differ_dir/README +0 -1
- data/tools/common/common/test/data/file_differ_dir/subdir/toto.txt +0 -53
- data/tools/common/common/test/data/file_differ_dir/subdirtwo/Hello +0 -0
- data/tools/common/common/test/data/find_test/__init__.py +0 -0
- data/tools/common/common/test/data/find_test/foo.txt +0 -0
- data/tools/common/common/test/data/find_test/module.py +0 -0
- data/tools/common/common/test/data/find_test/module2.py +0 -0
- data/tools/common/common/test/data/find_test/newlines.txt +0 -0
- data/tools/common/common/test/data/find_test/noendingnewline.py +0 -0
- data/tools/common/common/test/data/find_test/nonregr.py +0 -0
- data/tools/common/common/test/data/find_test/normal_file.txt +0 -0
- data/tools/common/common/test/data/find_test/spam.txt +0 -0
- data/tools/common/common/test/data/find_test/sub/doc.txt +0 -0
- data/tools/common/common/test/data/find_test/sub/momo.py +0 -0
- data/tools/common/common/test/data/find_test/test.ini +0 -0
- data/tools/common/common/test/data/find_test/test1.msg +0 -0
- data/tools/common/common/test/data/find_test/test2.msg +0 -0
- data/tools/common/common/test/data/find_test/write_protected_file.txt +0 -0
- data/tools/common/common/test/data/foo.txt +0 -9
- data/tools/common/common/test/data/module.py +0 -88
- data/tools/common/common/test/data/module2.py +0 -77
- data/tools/common/common/test/data/newlines.txt +0 -3
- data/tools/common/common/test/data/noendingnewline.py +0 -36
- data/tools/common/common/test/data/nonregr.py +0 -14
- data/tools/common/common/test/data/normal_file.txt +0 -0
- data/tools/common/common/test/data/reference_dir/NOTHING +0 -0
- data/tools/common/common/test/data/reference_dir/README +0 -1
- data/tools/common/common/test/data/reference_dir/subdir/coin +0 -1
- data/tools/common/common/test/data/reference_dir/subdir/toto.txt +0 -53
- data/tools/common/common/test/data/same_dir/NOTHING +0 -0
- data/tools/common/common/test/data/same_dir/README +0 -1
- data/tools/common/common/test/data/same_dir/subdir/coin +0 -1
- data/tools/common/common/test/data/same_dir/subdir/toto.txt +0 -53
- data/tools/common/common/test/data/spam.txt +0 -9
- data/tools/common/common/test/data/sub/doc.txt +0 -1
- data/tools/common/common/test/data/sub/momo.py +0 -1
- data/tools/common/common/test/data/subdir_differ_dir/NOTHING +0 -0
- data/tools/common/common/test/data/subdir_differ_dir/README +0 -1
- data/tools/common/common/test/data/subdir_differ_dir/subdir/coin +0 -1
- data/tools/common/common/test/data/subdir_differ_dir/subdir/toto.txt +0 -53
- data/tools/common/common/test/data/test.ini +0 -20
- data/tools/common/common/test/data/test1.msg +0 -30
- data/tools/common/common/test/data/test2.msg +0 -42
- data/tools/common/common/test/data/write_protected_file.txt +0 -0
- data/tools/common/common/test/foomod.py +0 -17
- data/tools/common/common/test/unittest_cache.py +0 -129
- data/tools/common/common/test/unittest_changelog.py +0 -37
- data/tools/common/common/test/unittest_compat.py +0 -239
- data/tools/common/common/test/unittest_configuration.py +0 -348
- data/tools/common/common/test/unittest_date.py +0 -154
- data/tools/common/common/test/unittest_decorators.py +0 -62
- data/tools/common/common/test/unittest_deprecation.py +0 -76
- data/tools/common/common/test/unittest_fileutils.py +0 -133
- data/tools/common/common/test/unittest_graph.py +0 -50
- data/tools/common/common/test/unittest_html.py +0 -76
- data/tools/common/common/test/unittest_interface.py +0 -87
- data/tools/common/common/test/unittest_modutils.py +0 -244
- data/tools/common/common/test/unittest_pytest.py +0 -50
- data/tools/common/common/test/unittest_shellutils.py +0 -248
- data/tools/common/common/test/unittest_table.py +0 -448
- data/tools/common/common/test/unittest_taskqueue.py +0 -71
- data/tools/common/common/test/unittest_testlib.py +0 -956
- data/tools/common/common/test/unittest_textutils.py +0 -247
- data/tools/common/common/test/unittest_tree.py +0 -248
- data/tools/common/common/test/unittest_umessage.py +0 -55
- data/tools/common/common/test/unittest_ureports_html.py +0 -64
- data/tools/common/common/test/unittest_ureports_text.py +0 -105
- data/tools/common/common/test/unittest_xmlutils.py +0 -75
- data/tools/common/common/test/utils.py +0 -87
- data/tools/common/common/testlib.py +0 -1927
- data/tools/common/common/textutils.py +0 -476
- data/tools/common/common/tree.py +0 -372
- data/tools/common/common/umessage.py +0 -161
- data/tools/common/common/ureports/__init__.py +0 -174
- data/tools/common/common/ureports/docbook_writer.py +0 -139
- data/tools/common/common/ureports/html_writer.py +0 -131
- data/tools/common/common/ureports/nodes.py +0 -201
- data/tools/common/common/ureports/text_writer.py +0 -140
- data/tools/common/common/vcgutils.py +0 -216
- data/tools/common/common/visitor.py +0 -107
- data/tools/common/common/xmlrpcutils.py +0 -136
- data/tools/common/common/xmlutils.py +0 -61
- data/tools/coverage/coverage.py +0 -602
- data/tools/epydoc/__init__.py +0 -227
- data/tools/epydoc/__init__.pyc +0 -0
- data/tools/epydoc/apidoc.py +0 -2203
- data/tools/epydoc/apidoc.pyc +0 -0
- data/tools/epydoc/checker.py +0 -349
- data/tools/epydoc/checker.pyc +0 -0
- data/tools/epydoc/cli.py +0 -1470
- data/tools/epydoc/cli.pyc +0 -0
- data/tools/epydoc/compat.py +0 -250
- data/tools/epydoc/compat.pyc +0 -0
- data/tools/epydoc/docbuilder.py +0 -1358
- data/tools/epydoc/docbuilder.pyc +0 -0
- data/tools/epydoc/docintrospecter.py +0 -1056
- data/tools/epydoc/docintrospecter.pyc +0 -0
- data/tools/epydoc/docparser.py +0 -2113
- data/tools/epydoc/docparser.pyc +0 -0
- data/tools/epydoc/docstringparser.py +0 -1111
- data/tools/epydoc/docstringparser.pyc +0 -0
- data/tools/epydoc/docwriter/__init__.py +0 -12
- data/tools/epydoc/docwriter/__init__.pyc +0 -0
- data/tools/epydoc/docwriter/dotgraph.py +0 -1351
- data/tools/epydoc/docwriter/dotgraph.pyc +0 -0
- data/tools/epydoc/docwriter/html.py +0 -3491
- data/tools/epydoc/docwriter/html.pyc +0 -0
- data/tools/epydoc/docwriter/html_colorize.py +0 -909
- data/tools/epydoc/docwriter/html_colorize.pyc +0 -0
- data/tools/epydoc/docwriter/html_css.py +0 -550
- data/tools/epydoc/docwriter/html_css.pyc +0 -0
- data/tools/epydoc/docwriter/html_help.py +0 -190
- data/tools/epydoc/docwriter/html_help.pyc +0 -0
- data/tools/epydoc/docwriter/latex.py +0 -1187
- data/tools/epydoc/docwriter/latex.pyc +0 -0
- data/tools/epydoc/docwriter/plaintext.py +0 -276
- data/tools/epydoc/docwriter/plaintext.pyc +0 -0
- data/tools/epydoc/docwriter/xlink.py +0 -505
- data/tools/epydoc/docwriter/xlink.pyc +0 -0
- data/tools/epydoc/gui.py +0 -1148
- data/tools/epydoc/gui.pyc +0 -0
- data/tools/epydoc/log.py +0 -204
- data/tools/epydoc/log.pyc +0 -0
- data/tools/epydoc/markup/__init__.py +0 -623
- data/tools/epydoc/markup/__init__.pyc +0 -0
- data/tools/epydoc/markup/doctest.py +0 -311
- data/tools/epydoc/markup/doctest.pyc +0 -0
- data/tools/epydoc/markup/epytext.py +0 -2116
- data/tools/epydoc/markup/epytext.pyc +0 -0
- data/tools/epydoc/markup/javadoc.py +0 -250
- data/tools/epydoc/markup/javadoc.pyc +0 -0
- data/tools/epydoc/markup/plaintext.py +0 -78
- data/tools/epydoc/markup/plaintext.pyc +0 -0
- data/tools/epydoc/markup/pyval_repr.py +0 -532
- data/tools/epydoc/markup/pyval_repr.pyc +0 -0
- data/tools/epydoc/markup/restructuredtext.py +0 -906
- data/tools/epydoc/markup/restructuredtext.pyc +0 -0
- data/tools/epydoc/test/__init__.py +0 -97
- data/tools/epydoc/test/__init__.pyc +0 -0
- data/tools/epydoc/test/util.py +0 -226
- data/tools/epydoc/test/util.pyc +0 -0
- data/tools/epydoc/util.py +0 -289
- data/tools/epydoc/util.pyc +0 -0
- data/tools/logilab/logilab/__init__.py +0 -5
- data/tools/logilab/logilab/astng/__init__.py +0 -82
- data/tools/logilab/logilab/astng/__pkginfo__.py +0 -76
- data/tools/logilab/logilab/astng/_exceptions.py +0 -64
- data/tools/logilab/logilab/astng/_nodes_ast.py +0 -667
- data/tools/logilab/logilab/astng/_nodes_compiler.py +0 -758
- data/tools/logilab/logilab/astng/bases.py +0 -608
- data/tools/logilab/logilab/astng/builder.py +0 -239
- data/tools/logilab/logilab/astng/inference.py +0 -426
- data/tools/logilab/logilab/astng/inspector.py +0 -289
- data/tools/logilab/logilab/astng/manager.py +0 -421
- data/tools/logilab/logilab/astng/mixins.py +0 -165
- data/tools/logilab/logilab/astng/node_classes.py +0 -848
- data/tools/logilab/logilab/astng/nodes.py +0 -85
- data/tools/logilab/logilab/astng/nodes_as_string.py +0 -389
- data/tools/logilab/logilab/astng/patchcomptransformer.py +0 -159
- data/tools/logilab/logilab/astng/protocols.py +0 -333
- data/tools/logilab/logilab/astng/raw_building.py +0 -212
- data/tools/logilab/logilab/astng/rebuilder.py +0 -307
- data/tools/logilab/logilab/astng/scoped_nodes.py +0 -951
- data/tools/logilab/logilab/astng/test/__init__.py +0 -19
- data/tools/logilab/logilab/astng/test/data/MyPyPa-0.1.0-py2.5.egg +0 -0
- data/tools/logilab/logilab/astng/test/data/MyPyPa-0.1.0-py2.5.zip +0 -0
- data/tools/logilab/logilab/astng/test/data/SSL1/Connection1.py +0 -33
- data/tools/logilab/logilab/astng/test/data/SSL1/__init__.py +0 -20
- data/tools/logilab/logilab/astng/test/data/__init__.py +0 -20
- data/tools/logilab/logilab/astng/test/data/all.py +0 -29
- data/tools/logilab/logilab/astng/test/data/appl/__init__.py +0 -23
- data/tools/logilab/logilab/astng/test/data/appl/myConnection.py +0 -30
- data/tools/logilab/logilab/astng/test/data/format.py +0 -34
- data/tools/logilab/logilab/astng/test/data/module.py +0 -90
- data/tools/logilab/logilab/astng/test/data/module2.py +0 -112
- data/tools/logilab/logilab/astng/test/data/noendingnewline.py +0 -57
- data/tools/logilab/logilab/astng/test/data/nonregr.py +0 -76
- data/tools/logilab/logilab/astng/test/data/notall.py +0 -28
- data/tools/logilab/logilab/astng/test/data2/__init__.py +0 -20
- data/tools/logilab/logilab/astng/test/data2/clientmodule_test.py +0 -51
- data/tools/logilab/logilab/astng/test/data2/suppliermodule_test.py +0 -32
- data/tools/logilab/logilab/astng/test/regrtest.py +0 -135
- data/tools/logilab/logilab/astng/test/regrtest_data/absimport.py +0 -22
- data/tools/logilab/logilab/astng/test/regrtest_data/descriptor_crash.py +0 -31
- data/tools/logilab/logilab/astng/test/regrtest_data/import_package_subpackage_module.py +0 -68
- data/tools/logilab/logilab/astng/test/regrtest_data/package/__init__.py +0 -24
- data/tools/logilab/logilab/astng/test/regrtest_data/package/subpackage/__init__.py +0 -20
- data/tools/logilab/logilab/astng/test/regrtest_data/package/subpackage/module.py +0 -20
- data/tools/logilab/logilab/astng/test/unittest_builder.py +0 -684
- data/tools/logilab/logilab/astng/test/unittest_inference.py +0 -1112
- data/tools/logilab/logilab/astng/test/unittest_inspector.py +0 -105
- data/tools/logilab/logilab/astng/test/unittest_lookup.py +0 -302
- data/tools/logilab/logilab/astng/test/unittest_manager.py +0 -98
- data/tools/logilab/logilab/astng/test/unittest_nodes.py +0 -302
- data/tools/logilab/logilab/astng/test/unittest_scoped_nodes.py +0 -501
- data/tools/logilab/logilab/astng/test/unittest_utils.py +0 -104
- data/tools/logilab/logilab/astng/utils.py +0 -342
- data/tools/logilab/logilab/common/__init__.py +0 -140
- data/tools/logilab/logilab/common/__pkginfo__.py +0 -43
- data/tools/logilab/logilab/common/adbh.py +0 -35
- data/tools/logilab/logilab/common/cache.py +0 -114
- data/tools/logilab/logilab/common/changelog.py +0 -234
- data/tools/logilab/logilab/common/clcommands.py +0 -181
- data/tools/logilab/logilab/common/cli.py +0 -212
- data/tools/logilab/logilab/common/compat.py +0 -328
- data/tools/logilab/logilab/common/configuration.py +0 -1087
- data/tools/logilab/logilab/common/contexts.py +0 -58
- data/tools/logilab/logilab/common/corbautils.py +0 -117
- data/tools/logilab/logilab/common/daemon.py +0 -171
- data/tools/logilab/logilab/common/date.py +0 -279
- data/tools/logilab/logilab/common/db.py +0 -49
- data/tools/logilab/logilab/common/dbf.py +0 -229
- data/tools/logilab/logilab/common/debugger.py +0 -208
- data/tools/logilab/logilab/common/decorators.py +0 -190
- data/tools/logilab/logilab/common/deprecation.py +0 -118
- data/tools/logilab/logilab/common/fileutils.py +0 -409
- data/tools/logilab/logilab/common/graph.py +0 -259
- data/tools/logilab/logilab/common/html.py +0 -142
- data/tools/logilab/logilab/common/interface.py +0 -76
- data/tools/logilab/logilab/common/logging_ext.py +0 -166
- data/tools/logilab/logilab/common/modutils.py +0 -670
- data/tools/logilab/logilab/common/optik_ext.py +0 -383
- data/tools/logilab/logilab/common/optparser.py +0 -92
- data/tools/logilab/logilab/common/pdf_ext.py +0 -111
- data/tools/logilab/logilab/common/proc.py +0 -276
- data/tools/logilab/logilab/common/pyro_ext.py +0 -146
- data/tools/logilab/logilab/common/pytest.py +0 -754
- data/tools/logilab/logilab/common/shellutils.py +0 -383
- data/tools/logilab/logilab/common/sphinx_ext.py +0 -87
- data/tools/logilab/logilab/common/sphinxutils.py +0 -122
- data/tools/logilab/logilab/common/sqlgen.py +0 -31
- data/tools/logilab/logilab/common/table.py +0 -930
- data/tools/logilab/logilab/common/tasksqueue.py +0 -97
- data/tools/logilab/logilab/common/test/__init__.py +0 -1
- data/tools/logilab/logilab/common/test/data/ChangeLog +0 -184
- data/tools/logilab/logilab/common/test/data/MyPyPa-0.1.0-py2.5.egg +0 -0
- data/tools/logilab/logilab/common/test/data/__init__.py +0 -1
- data/tools/logilab/logilab/common/test/data/content_differ_dir/NOTHING +0 -0
- data/tools/logilab/logilab/common/test/data/content_differ_dir/README +0 -1
- data/tools/logilab/logilab/common/test/data/content_differ_dir/subdir/coin +0 -1
- data/tools/logilab/logilab/common/test/data/content_differ_dir/subdir/toto.txt +0 -53
- data/tools/logilab/logilab/common/test/data/file_differ_dir/NOTHING +0 -0
- data/tools/logilab/logilab/common/test/data/file_differ_dir/README +0 -1
- data/tools/logilab/logilab/common/test/data/file_differ_dir/subdir/toto.txt +0 -53
- data/tools/logilab/logilab/common/test/data/file_differ_dir/subdirtwo/Hello +0 -0
- data/tools/logilab/logilab/common/test/data/find_test/__init__.py +0 -0
- data/tools/logilab/logilab/common/test/data/find_test/foo.txt +0 -0
- data/tools/logilab/logilab/common/test/data/find_test/module.py +0 -0
- data/tools/logilab/logilab/common/test/data/find_test/module2.py +0 -0
- data/tools/logilab/logilab/common/test/data/find_test/newlines.txt +0 -0
- data/tools/logilab/logilab/common/test/data/find_test/noendingnewline.py +0 -0
- data/tools/logilab/logilab/common/test/data/find_test/nonregr.py +0 -0
- data/tools/logilab/logilab/common/test/data/find_test/normal_file.txt +0 -0
- data/tools/logilab/logilab/common/test/data/find_test/spam.txt +0 -0
- data/tools/logilab/logilab/common/test/data/find_test/sub/doc.txt +0 -0
- data/tools/logilab/logilab/common/test/data/find_test/sub/momo.py +0 -0
- data/tools/logilab/logilab/common/test/data/find_test/test.ini +0 -0
- data/tools/logilab/logilab/common/test/data/find_test/test1.msg +0 -0
- data/tools/logilab/logilab/common/test/data/find_test/test2.msg +0 -0
- data/tools/logilab/logilab/common/test/data/find_test/write_protected_file.txt +0 -0
- data/tools/logilab/logilab/common/test/data/foo.txt +0 -9
- data/tools/logilab/logilab/common/test/data/module.py +0 -88
- data/tools/logilab/logilab/common/test/data/module2.py +0 -77
- data/tools/logilab/logilab/common/test/data/newlines.txt +0 -3
- data/tools/logilab/logilab/common/test/data/noendingnewline.py +0 -36
- data/tools/logilab/logilab/common/test/data/nonregr.py +0 -14
- data/tools/logilab/logilab/common/test/data/normal_file.txt +0 -0
- data/tools/logilab/logilab/common/test/data/reference_dir/NOTHING +0 -0
- data/tools/logilab/logilab/common/test/data/reference_dir/README +0 -1
- data/tools/logilab/logilab/common/test/data/reference_dir/subdir/coin +0 -1
- data/tools/logilab/logilab/common/test/data/reference_dir/subdir/toto.txt +0 -53
- data/tools/logilab/logilab/common/test/data/same_dir/NOTHING +0 -0
- data/tools/logilab/logilab/common/test/data/same_dir/README +0 -1
- data/tools/logilab/logilab/common/test/data/same_dir/subdir/coin +0 -1
- data/tools/logilab/logilab/common/test/data/same_dir/subdir/toto.txt +0 -53
- data/tools/logilab/logilab/common/test/data/spam.txt +0 -9
- data/tools/logilab/logilab/common/test/data/sub/doc.txt +0 -1
- data/tools/logilab/logilab/common/test/data/sub/momo.py +0 -1
- data/tools/logilab/logilab/common/test/data/subdir_differ_dir/NOTHING +0 -0
- data/tools/logilab/logilab/common/test/data/subdir_differ_dir/README +0 -1
- data/tools/logilab/logilab/common/test/data/subdir_differ_dir/subdir/coin +0 -1
- data/tools/logilab/logilab/common/test/data/subdir_differ_dir/subdir/toto.txt +0 -53
- data/tools/logilab/logilab/common/test/data/test.ini +0 -20
- data/tools/logilab/logilab/common/test/data/test1.msg +0 -30
- data/tools/logilab/logilab/common/test/data/test2.msg +0 -42
- data/tools/logilab/logilab/common/test/data/write_protected_file.txt +0 -0
- data/tools/logilab/logilab/common/test/foomod.py +0 -17
- data/tools/logilab/logilab/common/test/unittest_cache.py +0 -129
- data/tools/logilab/logilab/common/test/unittest_changelog.py +0 -37
- data/tools/logilab/logilab/common/test/unittest_compat.py +0 -239
- data/tools/logilab/logilab/common/test/unittest_configuration.py +0 -348
- data/tools/logilab/logilab/common/test/unittest_date.py +0 -154
- data/tools/logilab/logilab/common/test/unittest_decorators.py +0 -62
- data/tools/logilab/logilab/common/test/unittest_deprecation.py +0 -76
- data/tools/logilab/logilab/common/test/unittest_fileutils.py +0 -133
- data/tools/logilab/logilab/common/test/unittest_graph.py +0 -50
- data/tools/logilab/logilab/common/test/unittest_html.py +0 -76
- data/tools/logilab/logilab/common/test/unittest_interface.py +0 -87
- data/tools/logilab/logilab/common/test/unittest_modutils.py +0 -244
- data/tools/logilab/logilab/common/test/unittest_pytest.py +0 -50
- data/tools/logilab/logilab/common/test/unittest_shellutils.py +0 -248
- data/tools/logilab/logilab/common/test/unittest_table.py +0 -448
- data/tools/logilab/logilab/common/test/unittest_taskqueue.py +0 -71
- data/tools/logilab/logilab/common/test/unittest_testlib.py +0 -956
- data/tools/logilab/logilab/common/test/unittest_textutils.py +0 -247
- data/tools/logilab/logilab/common/test/unittest_tree.py +0 -248
- data/tools/logilab/logilab/common/test/unittest_umessage.py +0 -55
- data/tools/logilab/logilab/common/test/unittest_ureports_html.py +0 -64
- data/tools/logilab/logilab/common/test/unittest_ureports_text.py +0 -105
- data/tools/logilab/logilab/common/test/unittest_xmlutils.py +0 -75
- data/tools/logilab/logilab/common/test/utils.py +0 -87
- data/tools/logilab/logilab/common/testlib.py +0 -1927
- data/tools/logilab/logilab/common/textutils.py +0 -476
- data/tools/logilab/logilab/common/tree.py +0 -372
- data/tools/logilab/logilab/common/umessage.py +0 -161
- data/tools/logilab/logilab/common/ureports/__init__.py +0 -174
- data/tools/logilab/logilab/common/ureports/docbook_writer.py +0 -139
- data/tools/logilab/logilab/common/ureports/html_writer.py +0 -131
- data/tools/logilab/logilab/common/ureports/nodes.py +0 -201
- data/tools/logilab/logilab/common/ureports/text_writer.py +0 -140
- data/tools/logilab/logilab/common/vcgutils.py +0 -216
- data/tools/logilab/logilab/common/visitor.py +0 -107
- data/tools/logilab/logilab/common/xmlrpcutils.py +0 -136
- data/tools/logilab/logilab/common/xmlutils.py +0 -61
- data/tools/pychecker/COPYRIGHT +0 -31
- data/tools/pychecker/ChangeLog +0 -349
- data/tools/pychecker/CodeChecks.py +0 -1969
- data/tools/pychecker/CodeChecks.pyc +0 -0
- data/tools/pychecker/CodeChecks.pyo +0 -0
- data/tools/pychecker/Config.py +0 -475
- data/tools/pychecker/Config.pyc +0 -0
- data/tools/pychecker/Config.pyo +0 -0
- data/tools/pychecker/KNOWN_BUGS +0 -100
- data/tools/pychecker/MAINTAINERS +0 -81
- data/tools/pychecker/NEWS +0 -406
- data/tools/pychecker/OP.py +0 -131
- data/tools/pychecker/OP.pyc +0 -0
- data/tools/pychecker/OP.pyo +0 -0
- data/tools/pychecker/OptionTypes.py +0 -117
- data/tools/pychecker/OptionTypes.pyc +0 -0
- data/tools/pychecker/OptionTypes.pyo +0 -0
- data/tools/pychecker/README +0 -152
- data/tools/pychecker/Stack.py +0 -115
- data/tools/pychecker/Stack.pyc +0 -0
- data/tools/pychecker/Stack.pyo +0 -0
- data/tools/pychecker/TODO +0 -101
- data/tools/pychecker/VERSION +0 -1
- data/tools/pychecker/Warning.py +0 -50
- data/tools/pychecker/Warning.pyc +0 -0
- data/tools/pychecker/Warning.pyo +0 -0
- data/tools/pychecker/__init__.py +0 -17
- data/tools/pychecker/__init__.pyc +0 -0
- data/tools/pychecker/__init__.pyo +0 -0
- data/tools/pychecker/checker.py +0 -961
- data/tools/pychecker/checker.pyc +0 -0
- data/tools/pychecker/checker.pyo +0 -0
- data/tools/pychecker/function.py +0 -159
- data/tools/pychecker/function.pyc +0 -0
- data/tools/pychecker/function.pyo +0 -0
- data/tools/pychecker/msgs.py +0 -175
- data/tools/pychecker/msgs.pyc +0 -0
- data/tools/pychecker/msgs.pyo +0 -0
- data/tools/pychecker/options.py +0 -275
- data/tools/pychecker/options.pyc +0 -0
- data/tools/pychecker/options.pyo +0 -0
- data/tools/pychecker/pcmodules.py +0 -19
- data/tools/pychecker/pcmodules.pyc +0 -0
- data/tools/pychecker/pcmodules.pyo +0 -0
- data/tools/pychecker/printer.py +0 -47
- data/tools/pychecker/printer.pyc +0 -0
- data/tools/pychecker/printer.pyo +0 -0
- data/tools/pychecker/python.py +0 -427
- data/tools/pychecker/python.pyc +0 -0
- data/tools/pychecker/python.pyo +0 -0
- data/tools/pychecker/utils.py +0 -102
- data/tools/pychecker/utils.pyc +0 -0
- data/tools/pychecker/utils.pyo +0 -0
- data/tools/pychecker/warn.py +0 -778
- data/tools/pychecker/warn.pyc +0 -0
- data/tools/pychecker/warn.pyo +0 -0
- data/tools/pylint2/pylint/__init__.py +0 -16
- data/tools/pylint2/pylint/__pkginfo__.py +0 -67
- data/tools/pylint2/pylint/checkers/__init__.py +0 -155
- data/tools/pylint2/pylint/checkers/base.py +0 -749
- data/tools/pylint2/pylint/checkers/classes.py +0 -527
- data/tools/pylint2/pylint/checkers/design_analysis.py +0 -344
- data/tools/pylint2/pylint/checkers/exceptions.py +0 -183
- data/tools/pylint2/pylint/checkers/format.py +0 -367
- data/tools/pylint2/pylint/checkers/imports.py +0 -379
- data/tools/pylint2/pylint/checkers/logging.py +0 -98
- data/tools/pylint2/pylint/checkers/misc.py +0 -128
- data/tools/pylint2/pylint/checkers/newstyle.py +0 -107
- data/tools/pylint2/pylint/checkers/raw_metrics.py +0 -125
- data/tools/pylint2/pylint/checkers/similar.py +0 -333
- data/tools/pylint2/pylint/checkers/string_format.py +0 -239
- data/tools/pylint2/pylint/checkers/typecheck.py +0 -364
- data/tools/pylint2/pylint/checkers/utils.py +0 -208
- data/tools/pylint2/pylint/checkers/variables.py +0 -498
- data/tools/pylint2/pylint/config.py +0 -149
- data/tools/pylint2/pylint/epylint.py +0 -149
- data/tools/pylint2/pylint/gui.py +0 -433
- data/tools/pylint2/pylint/interfaces.py +0 -98
- data/tools/pylint2/pylint/lint.py +0 -914
- data/tools/pylint2/pylint/pyreverse/__init__.py +0 -5
- data/tools/pylint2/pylint/pyreverse/diadefslib.py +0 -229
- data/tools/pylint2/pylint/pyreverse/diagrams.py +0 -247
- data/tools/pylint2/pylint/pyreverse/main.py +0 -123
- data/tools/pylint2/pylint/pyreverse/utils.py +0 -131
- data/tools/pylint2/pylint/pyreverse/writer.py +0 -196
- data/tools/pylint2/pylint/reporters/__init__.py +0 -67
- data/tools/pylint2/pylint/reporters/guireporter.py +0 -36
- data/tools/pylint2/pylint/reporters/html.py +0 -69
- data/tools/pylint2/pylint/reporters/text.py +0 -156
- data/tools/pylint2/pylint/utils.py +0 -518
- data/tools/pylint2/pylint.py +0 -16
@@ -1,498 +0,0 @@
|
|
1
|
-
# Copyright (c) 2003-2010 LOGILAB S.A. (Paris, FRANCE).
|
2
|
-
# http://www.logilab.fr/ -- mailto:contact@logilab.fr
|
3
|
-
#
|
4
|
-
# This program is free software; you can redistribute it and/or modify it under
|
5
|
-
# the terms of the GNU General Public License as published by the Free Software
|
6
|
-
# Foundation; either version 2 of the License, or (at your option) any later
|
7
|
-
# version.
|
8
|
-
#
|
9
|
-
# This program is distributed in the hope that it will be useful, but WITHOUT
|
10
|
-
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
11
|
-
# FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
12
|
-
#
|
13
|
-
# You should have received a copy of the GNU General Public License along with
|
14
|
-
# this program; if not, write to the Free Software Foundation, Inc.,
|
15
|
-
# 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
16
|
-
"""variables checkers for Python code
|
17
|
-
"""
|
18
|
-
|
19
|
-
from copy import copy
|
20
|
-
|
21
|
-
from logilab.common.compat import enumerate
|
22
|
-
from logilab import astng
|
23
|
-
from logilab.astng import are_exclusive, builtin_lookup
|
24
|
-
|
25
|
-
from pylint.interfaces import IASTNGChecker
|
26
|
-
from pylint.checkers import BaseChecker
|
27
|
-
from pylint.checkers.utils import PYMETHODS, is_ancestor_name, is_builtin, \
|
28
|
-
is_defined_before, is_error, is_func_default, is_func_decorator, assign_parent
|
29
|
-
|
30
|
-
|
31
|
-
def overridden_method(klass, name):
|
32
|
-
"""get overridden method if any"""
|
33
|
-
try:
|
34
|
-
parent = klass.local_attr_ancestors(name).next()
|
35
|
-
except (StopIteration, KeyError):
|
36
|
-
return None
|
37
|
-
try:
|
38
|
-
meth_node = parent[name]
|
39
|
-
except KeyError:
|
40
|
-
# We have found an ancestor defining <name> but it's not in the local
|
41
|
-
# dictionary. This may happen with astng built from living objects.
|
42
|
-
return None
|
43
|
-
if isinstance(meth_node, astng.Function):
|
44
|
-
return meth_node
|
45
|
-
return None
|
46
|
-
|
47
|
-
|
48
|
-
MSGS = {
|
49
|
-
'E0601': ('Using variable %r before assignment',
|
50
|
-
'Used when a local variable is accessed before it\'s \
|
51
|
-
assignment.'),
|
52
|
-
'E0602': ('Undefined variable %r',
|
53
|
-
'Used when an undefined variable is accessed.'),
|
54
|
-
|
55
|
-
'E0611': ('No name %r in module %r',
|
56
|
-
'Used when a name cannot be found in a module.'),
|
57
|
-
|
58
|
-
'W0601': ('Global variable %r undefined at the module level',
|
59
|
-
'Used when a variable is defined through the "global" statement \
|
60
|
-
but the variable is not defined in the module scope.'),
|
61
|
-
'W0602': ('Using global for %r but no assignment is done',
|
62
|
-
'Used when a variable is defined through the "global" statement \
|
63
|
-
but no assignment to this variable is done.'),
|
64
|
-
'W0603': ('Using the global statement', # W0121
|
65
|
-
'Used when you use the "global" statement to update a global \
|
66
|
-
variable. PyLint just try to discourage this \
|
67
|
-
usage. That doesn\'t mean you can not use it !'),
|
68
|
-
'W0604': ('Using the global statement at the module level', # W0103
|
69
|
-
'Used when you use the "global" statement at the module level \
|
70
|
-
since it has no effect'),
|
71
|
-
'W0611': ('Unused import %s',
|
72
|
-
'Used when an imported module or variable is not used.'),
|
73
|
-
'W0612': ('Unused variable %r',
|
74
|
-
'Used when a variable is defined but not used.'),
|
75
|
-
'W0613': ('Unused argument %r',
|
76
|
-
'Used when a function or method argument is not used.'),
|
77
|
-
'W0614': ('Unused import %s from wildcard import',
|
78
|
-
'Used when an imported module or variable is not used from a \
|
79
|
-
\'from X import *\' style import.'),
|
80
|
-
|
81
|
-
'W0621': ('Redefining name %r from outer scope (line %s)',
|
82
|
-
'Used when a variable\'s name hide a name defined in the outer \
|
83
|
-
scope.'),
|
84
|
-
'W0622': ('Redefining built-in %r',
|
85
|
-
'Used when a variable or function override a built-in.'),
|
86
|
-
|
87
|
-
'W0631': ('Using possibly undefined loop variable %r',
|
88
|
-
'Used when an loop variable (i.e. defined by a for loop or \
|
89
|
-
a list comprehension or a generator expression) is used outside \
|
90
|
-
the loop.'),
|
91
|
-
}
|
92
|
-
|
93
|
-
class VariablesChecker(BaseChecker):
|
94
|
-
"""checks for
|
95
|
-
* unused variables / imports
|
96
|
-
* undefined variables
|
97
|
-
* redefinition of variable from builtins or from an outer scope
|
98
|
-
* use of variable before assignment
|
99
|
-
"""
|
100
|
-
|
101
|
-
__implements__ = IASTNGChecker
|
102
|
-
|
103
|
-
name = 'variables'
|
104
|
-
msgs = MSGS
|
105
|
-
priority = -1
|
106
|
-
options = (
|
107
|
-
("init-import",
|
108
|
-
{'default': 0, 'type' : 'yn', 'metavar' : '<y_or_n>',
|
109
|
-
'help' : 'Tells whether we should check for unused import in \
|
110
|
-
__init__ files.'}),
|
111
|
-
("dummy-variables-rgx",
|
112
|
-
{'default': ('_|dummy'),
|
113
|
-
'type' :'regexp', 'metavar' : '<regexp>',
|
114
|
-
'help' : 'A regular expression matching names used \
|
115
|
-
for dummy variables (i.e. not used).'}),
|
116
|
-
("additional-builtins",
|
117
|
-
{'default': (), 'type' : 'csv',
|
118
|
-
'metavar' : '<comma separated list>',
|
119
|
-
'help' : 'List of additional names supposed to be defined in \
|
120
|
-
builtins. Remember that you should avoid to define new builtins when possible.'
|
121
|
-
}),
|
122
|
-
)
|
123
|
-
def __init__(self, linter=None):
|
124
|
-
BaseChecker.__init__(self, linter)
|
125
|
-
self._to_consume = None
|
126
|
-
self._checking_mod_attr = None
|
127
|
-
self._vars = None
|
128
|
-
|
129
|
-
def visit_module(self, node):
|
130
|
-
"""visit module : update consumption analysis variable
|
131
|
-
checks globals doesn't overrides builtins
|
132
|
-
"""
|
133
|
-
self._to_consume = [(copy(node.locals), {}, 'module')]
|
134
|
-
self._vars = []
|
135
|
-
for name, stmts in node.locals.items():
|
136
|
-
if is_builtin(name):
|
137
|
-
# do not print Redefining builtin for additional builtins
|
138
|
-
self.add_message('W0622', args=name, node=stmts[0])
|
139
|
-
|
140
|
-
def leave_module(self, node):
|
141
|
-
"""leave module: check globals
|
142
|
-
"""
|
143
|
-
assert len(self._to_consume) == 1
|
144
|
-
not_consumed = self._to_consume.pop()[0]
|
145
|
-
# don't check unused imports in __init__ files
|
146
|
-
if not self.config.init_import and node.package:
|
147
|
-
return
|
148
|
-
for name, stmts in not_consumed.items():
|
149
|
-
stmt = stmts[0]
|
150
|
-
if isinstance(stmt, astng.Import):
|
151
|
-
self.add_message('W0611', args=name, node=stmt)
|
152
|
-
elif isinstance(stmt, astng.From) and stmt.modname != '__future__':
|
153
|
-
if stmt.names[0][0] == '*':
|
154
|
-
self.add_message('W0614', args=name, node=stmt)
|
155
|
-
else:
|
156
|
-
self.add_message('W0611', args=name, node=stmt)
|
157
|
-
del self._to_consume
|
158
|
-
del self._vars
|
159
|
-
|
160
|
-
def visit_class(self, node):
|
161
|
-
"""visit class: update consumption analysis variable
|
162
|
-
"""
|
163
|
-
self._to_consume.append((copy(node.locals), {}, 'class'))
|
164
|
-
|
165
|
-
def leave_class(self, _):
|
166
|
-
"""leave class: update consumption analysis variable
|
167
|
-
"""
|
168
|
-
# do not check for not used locals here (no sense)
|
169
|
-
self._to_consume.pop()
|
170
|
-
|
171
|
-
def visit_lambda(self, node):
|
172
|
-
"""visit lambda: update consumption analysis variable
|
173
|
-
"""
|
174
|
-
self._to_consume.append((copy(node.locals), {}, 'lambda'))
|
175
|
-
|
176
|
-
def leave_lambda(self, _):
|
177
|
-
"""leave lambda: update consumption analysis variable
|
178
|
-
"""
|
179
|
-
# do not check for not used locals here
|
180
|
-
self._to_consume.pop()
|
181
|
-
|
182
|
-
def visit_genexpr(self, node):
|
183
|
-
"""visit genexpr: update consumption analysis variable
|
184
|
-
"""
|
185
|
-
self._to_consume.append((copy(node.locals), {}, 'genexpr'))
|
186
|
-
|
187
|
-
def leave_genexpr(self, _):
|
188
|
-
"""leave genexpr: update consumption analysis variable
|
189
|
-
"""
|
190
|
-
# do not check for not used locals here
|
191
|
-
self._to_consume.pop()
|
192
|
-
|
193
|
-
def visit_function(self, node):
|
194
|
-
"""visit function: update consumption analysis variable and check locals
|
195
|
-
"""
|
196
|
-
globs = node.root().globals
|
197
|
-
for name, stmt in node.items():
|
198
|
-
if globs.has_key(name) and not isinstance(stmt, astng.Global):
|
199
|
-
line = globs[name][0].lineno
|
200
|
-
self.add_message('W0621', args=(name, line), node=stmt)
|
201
|
-
elif is_builtin(name):
|
202
|
-
# do not print Redefining builtin for additional builtins
|
203
|
-
self.add_message('W0622', args=name, node=stmt)
|
204
|
-
self._to_consume.append((copy(node.locals), {}, 'function'))
|
205
|
-
self._vars.append({})
|
206
|
-
|
207
|
-
def leave_function(self, node):
|
208
|
-
"""leave function: check function's locals are consumed"""
|
209
|
-
not_consumed = self._to_consume.pop()[0]
|
210
|
-
self._vars.pop(0)
|
211
|
-
# don't check arguments of function which are only raising an exception
|
212
|
-
if is_error(node):
|
213
|
-
return
|
214
|
-
# don't check arguments of abstract methods or within an interface
|
215
|
-
is_method = node.is_method()
|
216
|
-
klass = node.parent.frame()
|
217
|
-
if is_method and (klass.type == 'interface' or node.is_abstract()):
|
218
|
-
return
|
219
|
-
authorized_rgx = self.config.dummy_variables_rgx
|
220
|
-
overridden = marker = []
|
221
|
-
argnames = node.argnames()
|
222
|
-
for name, stmts in not_consumed.iteritems():
|
223
|
-
# ignore some special names specified by user configuration
|
224
|
-
if authorized_rgx.match(name):
|
225
|
-
continue
|
226
|
-
# ignore names imported by the global statement
|
227
|
-
# FIXME: should only ignore them if it's assigned latter
|
228
|
-
stmt = stmts[0]
|
229
|
-
if isinstance(stmt, astng.Global):
|
230
|
-
continue
|
231
|
-
# care about functions with unknown argument (builtins)
|
232
|
-
if name in argnames:
|
233
|
-
if is_method:
|
234
|
-
# don't warn for the first argument of a (non static) method
|
235
|
-
if node.type != 'staticmethod' and name == argnames[0]:
|
236
|
-
continue
|
237
|
-
# don't warn for argument of an overridden method
|
238
|
-
if overridden is marker:
|
239
|
-
overridden = overridden_method(klass, node.name)
|
240
|
-
if overridden is not None and name in overridden.argnames():
|
241
|
-
continue
|
242
|
-
if node.name in PYMETHODS and node.name not in ('__init__', '__new__'):
|
243
|
-
continue
|
244
|
-
# don't check callback arguments XXX should be configurable
|
245
|
-
if node.name.startswith('cb_') or node.name.endswith('_cb'):
|
246
|
-
continue
|
247
|
-
self.add_message('W0613', args=name, node=stmt)
|
248
|
-
else:
|
249
|
-
self.add_message('W0612', args=name, node=stmt)
|
250
|
-
|
251
|
-
def visit_global(self, node):
|
252
|
-
"""check names imported exists in the global scope"""
|
253
|
-
frame = node.frame()
|
254
|
-
if isinstance(frame, astng.Module):
|
255
|
-
self.add_message('W0604', node=node)
|
256
|
-
return
|
257
|
-
module = frame.root()
|
258
|
-
default_message = True
|
259
|
-
for name in node.names:
|
260
|
-
try:
|
261
|
-
assign_nodes = module.getattr(name)
|
262
|
-
except astng.NotFoundError:
|
263
|
-
# unassigned global, skip
|
264
|
-
assign_nodes = []
|
265
|
-
for anode in assign_nodes:
|
266
|
-
if anode.parent is None:
|
267
|
-
# node returned for builtin attribute such as __file__,
|
268
|
-
# __doc__, etc...
|
269
|
-
continue
|
270
|
-
if anode.frame() is frame:
|
271
|
-
# same scope level assignment
|
272
|
-
break
|
273
|
-
else:
|
274
|
-
# global but no assignment
|
275
|
-
self.add_message('W0602', args=name, node=node)
|
276
|
-
default_message = False
|
277
|
-
if not assign_nodes:
|
278
|
-
continue
|
279
|
-
for anode in assign_nodes:
|
280
|
-
if anode.parent is None:
|
281
|
-
self.add_message('W0622', args=name, node=node)
|
282
|
-
break
|
283
|
-
if anode.frame() is module:
|
284
|
-
# module level assignment
|
285
|
-
break
|
286
|
-
else:
|
287
|
-
# global undefined at the module scope
|
288
|
-
self.add_message('W0601', args=name, node=node)
|
289
|
-
default_message = False
|
290
|
-
if default_message:
|
291
|
-
self.add_message('W0603', node=node)
|
292
|
-
|
293
|
-
def _loopvar_name(self, node, name):
|
294
|
-
# filter variables according to node's scope
|
295
|
-
# XXX used to filter parents but don't remember why, and removing this
|
296
|
-
# fixes a W0631 false positive reported by Paul Hachmann on 2008/12 on
|
297
|
-
# python-projects (added to func_use_for_or_listcomp_var test)
|
298
|
-
#astmts = [stmt for stmt in node.lookup(name)[1]
|
299
|
-
# if hasattr(stmt, 'ass_type')] and
|
300
|
-
# not stmt.statement().parent_of(node)]
|
301
|
-
astmts = [stmt for stmt in node.lookup(name)[1]
|
302
|
-
if hasattr(stmt, 'ass_type')]
|
303
|
-
# filter variables according their respective scope
|
304
|
-
if not astmts or astmts[0].statement().parent_of(node):
|
305
|
-
_astmts = []
|
306
|
-
else:
|
307
|
-
_astmts = astmts[:1]
|
308
|
-
for i, stmt in enumerate(astmts[1:]):
|
309
|
-
if astmts[i].statement().parent_of(stmt):
|
310
|
-
continue
|
311
|
-
_astmts.append(stmt)
|
312
|
-
astmts = _astmts
|
313
|
-
if len(astmts) == 1:
|
314
|
-
ass = astmts[0].ass_type()
|
315
|
-
if isinstance(ass, (astng.For, astng.Comprehension, astng.GenExpr)) \
|
316
|
-
and not ass.statement() is node.statement():
|
317
|
-
self.add_message('W0631', args=name, node=node)
|
318
|
-
|
319
|
-
def visit_assname(self, node):
|
320
|
-
if isinstance(node.ass_type(), astng.AugAssign):
|
321
|
-
self.visit_name(node)
|
322
|
-
|
323
|
-
def visit_delname(self, node):
|
324
|
-
self.visit_name(node)
|
325
|
-
|
326
|
-
def visit_name(self, node):
|
327
|
-
"""check that a name is defined if the current scope and doesn't
|
328
|
-
redefine a built-in
|
329
|
-
"""
|
330
|
-
stmt = node.statement()
|
331
|
-
if stmt.fromlineno is None:
|
332
|
-
# name node from a astng built from live code, skip
|
333
|
-
assert not stmt.root().file.endswith('.py')
|
334
|
-
return
|
335
|
-
name = node.name
|
336
|
-
frame = stmt.scope()
|
337
|
-
# if the name node is used as a function default argument's value or as
|
338
|
-
# a decorator, then start from the parent frame of the function instead
|
339
|
-
# of the function frame - and thus open an inner class scope
|
340
|
-
if (is_func_default(node) or is_func_decorator(node)
|
341
|
-
or is_ancestor_name(frame, node)):
|
342
|
-
start_index = len(self._to_consume) - 2
|
343
|
-
else:
|
344
|
-
start_index = len(self._to_consume) - 1
|
345
|
-
# iterates through parent scopes, from the inner to the outer
|
346
|
-
base_scope_type = self._to_consume[start_index][-1]
|
347
|
-
for i in range(start_index, -1, -1):
|
348
|
-
to_consume, consumed, scope_type = self._to_consume[i]
|
349
|
-
# if the current scope is a class scope but it's not the inner
|
350
|
-
# scope, ignore it. This prevents to access this scope instead of
|
351
|
-
# the globals one in function members when there are some common
|
352
|
-
# names. The only exception is when the starting scope is a
|
353
|
-
# genexpr and its direct outer scope is a class
|
354
|
-
if scope_type == 'class' and i != start_index and not (
|
355
|
-
base_scope_type == 'genexpr' and i == start_index-1):
|
356
|
-
# XXX find a way to handle class scope in a smoother way
|
357
|
-
continue
|
358
|
-
# the name has already been consumed, only check it's not a loop
|
359
|
-
# variable used outside the loop
|
360
|
-
if consumed.has_key(name):
|
361
|
-
self._loopvar_name(node, name)
|
362
|
-
break
|
363
|
-
# mark the name as consumed if it's defined in this scope
|
364
|
-
# (i.e. no KeyError is raised by "to_consume[name]")
|
365
|
-
try:
|
366
|
-
consumed[name] = to_consume[name]
|
367
|
-
except KeyError:
|
368
|
-
continue
|
369
|
-
else:
|
370
|
-
# checks for use before assignment
|
371
|
-
defnode = assign_parent(to_consume[name][0])
|
372
|
-
if defnode is not None:
|
373
|
-
defstmt = defnode.statement()
|
374
|
-
defframe = defstmt.frame()
|
375
|
-
maybee0601 = True
|
376
|
-
if not frame is defframe:
|
377
|
-
maybee0601 = False
|
378
|
-
elif defframe.parent is None:
|
379
|
-
# we are at the module level, check the name is not
|
380
|
-
# defined in builtins
|
381
|
-
if name in defframe.scope_attrs or builtin_lookup(name)[1]:
|
382
|
-
maybee0601 = False
|
383
|
-
else:
|
384
|
-
# we are in a local scope, check the name is not
|
385
|
-
# defined in global or builtin scope
|
386
|
-
if defframe.root().lookup(name)[1]:
|
387
|
-
maybee0601 = False
|
388
|
-
if (maybee0601
|
389
|
-
and stmt.fromlineno <= defstmt.fromlineno
|
390
|
-
and not is_defined_before(node)
|
391
|
-
and not are_exclusive(stmt, defstmt, ('NameError', 'Exception', 'BaseException'))):
|
392
|
-
if defstmt is stmt and isinstance(node, (astng.DelName,
|
393
|
-
astng.AssName)):
|
394
|
-
self.add_message('E0602', args=name, node=node)
|
395
|
-
elif self._to_consume[-1][-1] != 'lambda':
|
396
|
-
# E0601 may *not* occurs in lambda scope
|
397
|
-
self.add_message('E0601', args=name, node=node)
|
398
|
-
if not isinstance(node, astng.AssName): # Aug AssName
|
399
|
-
del to_consume[name]
|
400
|
-
else:
|
401
|
-
del consumed[name]
|
402
|
-
# check it's not a loop variable used outside the loop
|
403
|
-
self._loopvar_name(node, name)
|
404
|
-
break
|
405
|
-
else:
|
406
|
-
# we have not found the name, if it isn't a builtin, that's an
|
407
|
-
# undefined name !
|
408
|
-
if not (name in astng.Module.scope_attrs or is_builtin(name)
|
409
|
-
or name in self.config.additional_builtins):
|
410
|
-
self.add_message('E0602', args=name, node=node)
|
411
|
-
|
412
|
-
def visit_import(self, node):
|
413
|
-
"""check modules attribute accesses"""
|
414
|
-
for name, _ in node.names:
|
415
|
-
parts = name.split('.')
|
416
|
-
try:
|
417
|
-
module = node.infer_name_module(parts[0]).next()
|
418
|
-
except astng.ResolveError:
|
419
|
-
continue
|
420
|
-
self._check_module_attrs(node, module, parts[1:])
|
421
|
-
|
422
|
-
def visit_from(self, node):
|
423
|
-
"""check modules attribute accesses"""
|
424
|
-
name_parts = node.modname.split('.')
|
425
|
-
try:
|
426
|
-
module = node.root().import_module(name_parts[0])
|
427
|
-
except KeyboardInterrupt:
|
428
|
-
raise
|
429
|
-
except:
|
430
|
-
return
|
431
|
-
module = self._check_module_attrs(node, module, name_parts[1:])
|
432
|
-
if not module:
|
433
|
-
return
|
434
|
-
for name, _ in node.names:
|
435
|
-
if name == '*':
|
436
|
-
continue
|
437
|
-
self._check_module_attrs(node, module, name.split('.'))
|
438
|
-
|
439
|
-
## def leave_getattr(self, node):
|
440
|
-
## """check modules attribute accesses
|
441
|
-
|
442
|
-
## this function is a "leave_" because when parsing 'a.b.c'
|
443
|
-
## we want to check the innermost expression first.
|
444
|
-
## """
|
445
|
-
## if isinstance(node.expr, astng.Name):
|
446
|
-
## try:
|
447
|
-
## module = node.expr.infer().next()
|
448
|
-
## except astng.InferenceError:
|
449
|
-
## return
|
450
|
-
## if not isinstance(module, astng.Module):
|
451
|
-
## # Not a module, don't check
|
452
|
-
## return
|
453
|
-
## elif self._checking_mod_attr is not None:
|
454
|
-
## module = self._checking_mod_attr
|
455
|
-
## else:
|
456
|
-
## return
|
457
|
-
## self._checking_mod_attr = self._check_module_attrs(node, module,
|
458
|
-
## [node.attrname])
|
459
|
-
|
460
|
-
## def leave_default(self, node):
|
461
|
-
## """by default, reset the _checking_mod_attr attribute"""
|
462
|
-
## self._checking_mod_attr = None
|
463
|
-
|
464
|
-
def _check_module_attrs(self, node, module, module_names):
|
465
|
-
"""check that module_names (list of string) are accessible through the
|
466
|
-
given module
|
467
|
-
if the latest access name corresponds to a module, return it
|
468
|
-
"""
|
469
|
-
assert isinstance(module, astng.Module), module
|
470
|
-
while module_names:
|
471
|
-
name = module_names.pop(0)
|
472
|
-
if name == '__dict__':
|
473
|
-
module = None
|
474
|
-
break
|
475
|
-
try:
|
476
|
-
module = module.getattr(name)[0].infer().next()
|
477
|
-
except astng.NotFoundError:
|
478
|
-
self.add_message('E0611', args=(name, module.name), node=node)
|
479
|
-
return None
|
480
|
-
except astng.InferenceError:
|
481
|
-
return None
|
482
|
-
if module_names:
|
483
|
-
# FIXME: other message if name is not the latest part of
|
484
|
-
# module_names ?
|
485
|
-
modname = module and module.name or '__dict__'
|
486
|
-
self.add_message('E0611', node=node,
|
487
|
-
args=('.'.join(module_names), modname))
|
488
|
-
return None
|
489
|
-
if isinstance(module, astng.Module):
|
490
|
-
return module
|
491
|
-
return None
|
492
|
-
|
493
|
-
|
494
|
-
|
495
|
-
|
496
|
-
def register(linter):
|
497
|
-
"""required method to auto register this checker"""
|
498
|
-
linter.register_checker(VariablesChecker(linter))
|
@@ -1,149 +0,0 @@
|
|
1
|
-
# This program is free software; you can redistribute it and/or modify it under
|
2
|
-
# the terms of the GNU General Public License as published by the Free Software
|
3
|
-
# Foundation; either version 2 of the License, or (at your option) any later
|
4
|
-
# version.
|
5
|
-
#
|
6
|
-
# This program is distributed in the hope that it will be useful, but WITHOUT
|
7
|
-
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
8
|
-
# FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details
|
9
|
-
#
|
10
|
-
# You should have received a copy of the GNU General Public License along with
|
11
|
-
# this program; if not, write to the Free Software Foundation, Inc.,
|
12
|
-
# 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
13
|
-
""" Copyright (c) 2003-2006 LOGILAB S.A. (Paris, FRANCE).
|
14
|
-
http://www.logilab.fr/ -- mailto:contact@logilab.fr
|
15
|
-
|
16
|
-
utilities for PyLint configuration :
|
17
|
-
_ pylintrc
|
18
|
-
_ pylint.d (PYLINT_HOME)
|
19
|
-
"""
|
20
|
-
|
21
|
-
import pickle
|
22
|
-
import os
|
23
|
-
import sys
|
24
|
-
from os.path import exists, isfile, join, expanduser, abspath, dirname
|
25
|
-
|
26
|
-
# pylint home is used to save old runs results ################################
|
27
|
-
|
28
|
-
USER_HOME = expanduser('~')
|
29
|
-
if os.environ.has_key('PYLINTHOME'):
|
30
|
-
PYLINT_HOME = os.environ['PYLINTHOME']
|
31
|
-
if USER_HOME == '~':
|
32
|
-
USER_HOME = dirname(PYLINT_HOME)
|
33
|
-
elif USER_HOME == '~':
|
34
|
-
PYLINT_HOME = ".pylint.d"
|
35
|
-
else:
|
36
|
-
PYLINT_HOME = join(USER_HOME, '.pylint.d')
|
37
|
-
|
38
|
-
if not exists(PYLINT_HOME):
|
39
|
-
try:
|
40
|
-
os.mkdir(PYLINT_HOME)
|
41
|
-
except OSError:
|
42
|
-
print >> sys.stderr, 'Unable to create directory %s' % PYLINT_HOME
|
43
|
-
|
44
|
-
def get_pdata_path(base_name, recurs):
|
45
|
-
"""return the path of the file which should contain old search data for the
|
46
|
-
given base_name with the given options values
|
47
|
-
"""
|
48
|
-
base_name = base_name.replace(os.sep, '_')
|
49
|
-
return join(PYLINT_HOME, "%s%s%s"%(base_name, recurs, '.stats'))
|
50
|
-
|
51
|
-
def load_results(base):
|
52
|
-
"""try to unpickle and return data from file if it exists and is not
|
53
|
-
corrupted
|
54
|
-
|
55
|
-
return an empty dictionary if it doesn't exists
|
56
|
-
"""
|
57
|
-
data_file = get_pdata_path(base, 1)
|
58
|
-
try:
|
59
|
-
return pickle.load(open(data_file))
|
60
|
-
except:
|
61
|
-
return {}
|
62
|
-
|
63
|
-
def save_results(results, base):
|
64
|
-
"""pickle results"""
|
65
|
-
data_file = get_pdata_path(base, 1)
|
66
|
-
try:
|
67
|
-
pickle.dump(results, open(data_file, 'w'))
|
68
|
-
except (IOError, OSError), ex:
|
69
|
-
print >> sys.stderr, 'Unable to create file %s: %s' % (data_file, ex)
|
70
|
-
|
71
|
-
# location of the configuration file ##########################################
|
72
|
-
|
73
|
-
|
74
|
-
def find_pylintrc():
|
75
|
-
"""search the pylint rc file and return its path if it find it, else None
|
76
|
-
"""
|
77
|
-
# is there a pylint rc file in the current directory ?
|
78
|
-
if exists('pylintrc'):
|
79
|
-
return abspath('pylintrc')
|
80
|
-
if isfile('__init__.py'):
|
81
|
-
curdir = abspath(os.getcwd())
|
82
|
-
while isfile(join(curdir, '__init__.py')):
|
83
|
-
curdir = abspath(join(curdir, '..'))
|
84
|
-
if isfile(join(curdir, 'pylintrc')):
|
85
|
-
return join(curdir, 'pylintrc')
|
86
|
-
if os.environ.has_key('PYLINTRC') and exists(os.environ['PYLINTRC']):
|
87
|
-
pylintrc = os.environ['PYLINTRC']
|
88
|
-
else:
|
89
|
-
user_home = expanduser('~')
|
90
|
-
if user_home == '~' or user_home == '/root':
|
91
|
-
pylintrc = ".pylintrc"
|
92
|
-
else:
|
93
|
-
pylintrc = join(user_home, '.pylintrc')
|
94
|
-
if not isfile(pylintrc):
|
95
|
-
if isfile('/etc/pylintrc'):
|
96
|
-
pylintrc = '/etc/pylintrc'
|
97
|
-
else:
|
98
|
-
pylintrc = None
|
99
|
-
return pylintrc
|
100
|
-
|
101
|
-
PYLINTRC = find_pylintrc()
|
102
|
-
|
103
|
-
ENV_HELP = '''
|
104
|
-
The following environment variables are used :
|
105
|
-
* PYLINTHOME
|
106
|
-
path to the directory where data of persistent run will be stored. If not
|
107
|
-
found, it defaults to ~/.pylint.d/ or .pylint.d (in the current working
|
108
|
-
directory) . The current PYLINTHOME is %(PYLINT_HOME)s.
|
109
|
-
* PYLINTRC
|
110
|
-
path to the configuration file. If not found, it will use the first
|
111
|
-
existent file in ~/.pylintrc, /etc/pylintrc. The current PYLINTRC is
|
112
|
-
%(PYLINTRC)s.
|
113
|
-
''' % globals()
|
114
|
-
|
115
|
-
# evaluation messages #########################################################
|
116
|
-
|
117
|
-
def get_note_message(note):
|
118
|
-
"""return a message according to note
|
119
|
-
note is a float < 10 (10 is the highest note)
|
120
|
-
"""
|
121
|
-
assert note <= 10, "Note is %.2f. Either you cheated, or pylint's \
|
122
|
-
broken!" % note
|
123
|
-
if note < 0:
|
124
|
-
msg = 'You have to do something quick !'
|
125
|
-
elif note < 1:
|
126
|
-
msg = 'Hey! This is really dreadful. Or maybe pylint is buggy?'
|
127
|
-
elif note < 2:
|
128
|
-
msg = "Come on! You can't be proud of this code"
|
129
|
-
elif note < 3:
|
130
|
-
msg = 'Hum... Needs work.'
|
131
|
-
elif note < 4:
|
132
|
-
msg = 'Wouldn\'t you be a bit lazy?'
|
133
|
-
elif note < 5:
|
134
|
-
msg = 'A little more work would make it acceptable.'
|
135
|
-
elif note < 6:
|
136
|
-
msg = 'Just the bare minimum. Give it a bit more polish. '
|
137
|
-
elif note < 7:
|
138
|
-
msg = 'This is okay-ish, but I\'m sure you can do better.'
|
139
|
-
elif note < 8:
|
140
|
-
msg = 'If you commit now, people should not be making nasty \
|
141
|
-
comments about you on c.l.py'
|
142
|
-
elif note < 9:
|
143
|
-
msg = 'That\'s pretty good. Good work mate.'
|
144
|
-
elif note < 10:
|
145
|
-
msg = 'So close to being perfect...'
|
146
|
-
else:
|
147
|
-
msg = 'Wow ! Now this deserves our uttermost respect.\nPlease send \
|
148
|
-
your code to python-projects@logilab.org'
|
149
|
-
return msg
|