exercism-analysis 0.1.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/exercism-analysis.gemspec +30 -0
- data/lib/exercism-analysis.rb +38 -0
- data/lib/exercism-analysis/adapters/adapter.rb +23 -0
- data/lib/exercism-analysis/adapters/clojure.rb +13 -0
- data/lib/exercism-analysis/adapters/go.rb +19 -0
- data/lib/exercism-analysis/adapters/javascript.rb +13 -0
- data/lib/exercism-analysis/adapters/python.rb +13 -0
- data/lib/exercism-analysis/adapters/ruby.rb +19 -0
- data/lib/exercism-analysis/analysis.rb +18 -0
- data/lib/exercism-analysis/analyzers/analyzer.rb +54 -0
- data/lib/exercism-analysis/analyzers/clojure/kibit.rb +25 -0
- data/lib/exercism-analysis/analyzers/go/golint.rb +23 -0
- data/lib/exercism-analysis/analyzers/javascript/jslint.rb +24 -0
- data/lib/exercism-analysis/analyzers/python/pylint.rb +24 -0
- data/lib/exercism-analysis/analyzers/ruby/control_flow.rb +21 -0
- data/lib/exercism-analysis/analyzers/ruby/enumerable_condition.rb +21 -0
- data/lib/exercism-analysis/analyzers/ruby/for_loop.rb +29 -0
- data/lib/exercism-analysis/analyzers/ruby/indentation.rb +21 -0
- data/lib/exercism-analysis/analyzers/ruby/iter_mutation.rb +37 -0
- data/lib/exercism-analysis/analyzers/ruby/output.rb +20 -0
- data/lib/exercism-analysis/analyzers/ruby/range.rb +28 -0
- data/lib/exercism-analysis/analyzers/ruby/roodi.rb +19 -0
- data/lib/exercism-analysis/analyzers/ruby/send.rb +25 -0
- data/lib/exercism-analysis/analyzers/ruby/shebang.rb +23 -0
- data/lib/exercism-analysis/analyzers/ruby/tab.rb +38 -0
- data/lib/exercism-analysis/processors/call_processor.rb +39 -0
- data/lib/exercism-analysis/processors/control_flow_processor.rb +27 -0
- data/lib/exercism-analysis/processors/enumerable_condition_processor.rb +31 -0
- data/lib/exercism-analysis/processors/for_loop_processor.rb +21 -0
- data/lib/exercism-analysis/processors/indentation_processor.rb +69 -0
- data/lib/exercism-analysis/processors/iter_mutation_processor.rb +50 -0
- data/lib/exercism-analysis/processors/processor.rb +34 -0
- data/lib/exercism-analysis/processors/range_processor.rb +23 -0
- data/lib/exercism-analysis/processors/send_processor.rb +23 -0
- data/lib/exercism-analysis/templates/each_to_map.rb +29 -0
- data/lib/exercism-analysis/templates/each_to_select.rb +31 -0
- data/lib/exercism-analysis/templates/range_exclusive.rb +19 -0
- data/lib/exercism-analysis/templates/template.rb +29 -0
- data/vendor/clojure/kibit-runner/LICENSE +214 -0
- data/vendor/clojure/kibit-runner/project.clj +10 -0
- data/vendor/clojure/kibit-runner/src/kibit_runner/core.clj +17 -0
- data/vendor/clojure/kibit-runner/target/kibit-runner-0.1.0-SNAPSHOT-standalone.jar +0 -0
- data/vendor/clojure/kibit-runner/target/kibit-runner-0.1.0-SNAPSHOT.jar +0 -0
- data/vendor/clojure/kibit-runner/target/stale/extract-native.dependencies +1 -0
- data/vendor/go/src/github.com/golang/lint/LICENSE +27 -0
- data/vendor/go/src/github.com/golang/lint/README +59 -0
- data/vendor/go/src/github.com/golang/lint/golint/golint.go +67 -0
- data/vendor/go/src/github.com/golang/lint/lint.go +1061 -0
- data/vendor/go/src/runner/golint_runner.go +23 -0
- data/vendor/javascript/jshint_runner.js +6 -0
- data/vendor/javascript/node_modules/jshint/README.md +47 -0
- data/vendor/javascript/node_modules/jshint/bin/apply +6 -0
- data/vendor/javascript/node_modules/jshint/bin/build +36 -0
- data/vendor/javascript/node_modules/jshint/bin/changelog +36 -0
- data/vendor/javascript/node_modules/jshint/bin/jshint +3 -0
- data/vendor/javascript/node_modules/jshint/bin/land +34 -0
- data/vendor/javascript/node_modules/jshint/data/ascii-identifier-data.js +22 -0
- data/vendor/javascript/node_modules/jshint/data/non-ascii-identifier-part-only.js +1570 -0
- data/vendor/javascript/node_modules/jshint/data/non-ascii-identifier-start.js +48477 -0
- data/vendor/javascript/node_modules/jshint/dist/jshint-rhino.js +60642 -0
- data/vendor/javascript/node_modules/jshint/dist/jshint.js +60525 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/README.md +196 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/cli.js +1139 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/examples/cat.js +17 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/examples/command.js +16 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/examples/echo.js +54 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/examples/glob.js +6 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/examples/long_desc.js +20 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/examples/progress.js +11 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/examples/sort.js +18 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/examples/spinner.js +9 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/examples/static.coffee +27 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/examples/static.js +25 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/index.js +1 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/node_modules/glob/LICENSE +27 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/node_modules/glob/README.md +250 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/node_modules/glob/examples/g.js +9 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/node_modules/glob/examples/usr-local.js +9 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/node_modules/glob/glob.js +728 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/node_modules/glob/node_modules/inherits/LICENSE +16 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/node_modules/glob/node_modules/inherits/README.md +42 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/node_modules/glob/node_modules/inherits/inherits.js +1 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/node_modules/glob/node_modules/inherits/inherits_browser.js +23 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/node_modules/glob/node_modules/inherits/package.json +51 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/node_modules/glob/node_modules/inherits/test.js +25 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/node_modules/glob/package.json +58 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/node_modules/glob/test/00-setup.js +176 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/node_modules/glob/test/bash-comparison.js +63 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/node_modules/glob/test/bash-results.json +351 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/node_modules/glob/test/cwd-test.js +55 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/node_modules/glob/test/globstar-match.js +19 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/node_modules/glob/test/mark.js +118 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/node_modules/glob/test/new-glob-optional-options.js +10 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/node_modules/glob/test/nocase-nomagic.js +113 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/node_modules/glob/test/pause-resume.js +73 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/node_modules/glob/test/readme-issue.js +36 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/node_modules/glob/test/root-nomount.js +39 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/node_modules/glob/test/root.js +46 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/node_modules/glob/test/stat.js +32 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/node_modules/glob/test/zz-cleanup.js +11 -0
- data/vendor/javascript/node_modules/jshint/node_modules/cli/package.json +70 -0
- data/vendor/javascript/node_modules/jshint/node_modules/console-browserify/LICENCE +19 -0
- data/vendor/javascript/node_modules/jshint/node_modules/console-browserify/README.md +33 -0
- data/vendor/javascript/node_modules/jshint/node_modules/console-browserify/index.js +86 -0
- data/vendor/javascript/node_modules/jshint/node_modules/console-browserify/node_modules/date-now/LICENCE +19 -0
- data/vendor/javascript/node_modules/jshint/node_modules/console-browserify/node_modules/date-now/README.md +45 -0
- data/vendor/javascript/node_modules/jshint/node_modules/console-browserify/node_modules/date-now/index.js +5 -0
- data/vendor/javascript/node_modules/jshint/node_modules/console-browserify/node_modules/date-now/package.json +89 -0
- data/vendor/javascript/node_modules/jshint/node_modules/console-browserify/node_modules/date-now/seed.js +16 -0
- data/vendor/javascript/node_modules/jshint/node_modules/console-browserify/node_modules/date-now/test/index.js +28 -0
- data/vendor/javascript/node_modules/jshint/node_modules/console-browserify/node_modules/date-now/test/static/index.html +10 -0
- data/vendor/javascript/node_modules/jshint/node_modules/console-browserify/package.json +88 -0
- data/vendor/javascript/node_modules/jshint/node_modules/console-browserify/test/index.js +67 -0
- data/vendor/javascript/node_modules/jshint/node_modules/console-browserify/test/static/index.html +12 -0
- data/vendor/javascript/node_modules/jshint/node_modules/console-browserify/test/static/test-adapter.js +53 -0
- data/vendor/javascript/node_modules/jshint/node_modules/exit/Gruntfile.js +48 -0
- data/vendor/javascript/node_modules/jshint/node_modules/exit/LICENSE-MIT +22 -0
- data/vendor/javascript/node_modules/jshint/node_modules/exit/README.md +75 -0
- data/vendor/javascript/node_modules/jshint/node_modules/exit/lib/exit.js +41 -0
- data/vendor/javascript/node_modules/jshint/node_modules/exit/package.json +69 -0
- data/vendor/javascript/node_modules/jshint/node_modules/exit/test/exit_test.js +121 -0
- data/vendor/javascript/node_modules/jshint/node_modules/exit/test/fixtures/10-stderr.txt +10 -0
- data/vendor/javascript/node_modules/jshint/node_modules/exit/test/fixtures/10-stdout-stderr.txt +20 -0
- data/vendor/javascript/node_modules/jshint/node_modules/exit/test/fixtures/10-stdout.txt +10 -0
- data/vendor/javascript/node_modules/jshint/node_modules/exit/test/fixtures/100-stderr.txt +100 -0
- data/vendor/javascript/node_modules/jshint/node_modules/exit/test/fixtures/100-stdout-stderr.txt +200 -0
- data/vendor/javascript/node_modules/jshint/node_modules/exit/test/fixtures/100-stdout.txt +100 -0
- data/vendor/javascript/node_modules/jshint/node_modules/exit/test/fixtures/1000-stderr.txt +1000 -0
- data/vendor/javascript/node_modules/jshint/node_modules/exit/test/fixtures/1000-stdout-stderr.txt +2000 -0
- data/vendor/javascript/node_modules/jshint/node_modules/exit/test/fixtures/1000-stdout.txt +1000 -0
- data/vendor/javascript/node_modules/jshint/node_modules/exit/test/fixtures/create-files.sh +8 -0
- data/vendor/javascript/node_modules/jshint/node_modules/exit/test/fixtures/log-broken.js +23 -0
- data/vendor/javascript/node_modules/jshint/node_modules/exit/test/fixtures/log.js +25 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/LICENSE +18 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/README.md +83 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/lib/CollectingHandler.js +55 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/lib/FeedHandler.js +95 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/lib/Parser.js +337 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/lib/ProxyHandler.js +27 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/lib/Stream.js +35 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/lib/Tokenizer.js +891 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/lib/WritableStream.js +21 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/lib/index.js +68 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domelementtype/LICENSE +11 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domelementtype/index.js +14 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domelementtype/package.json +40 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domelementtype/readme.md +1 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domhandler/LICENSE +11 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domhandler/index.js +211 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domhandler/package.json +68 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domhandler/readme.md +102 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domhandler/test/cases/01-basic.json +57 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domhandler/test/cases/02-single_tag_1.json +21 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domhandler/test/cases/03-single_tag_2.json +21 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domhandler/test/cases/04-unescaped_in_script.json +27 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domhandler/test/cases/05-tags_in_comment.json +18 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domhandler/test/cases/06-comment_in_script.json +18 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domhandler/test/cases/07-unescaped_in_style.json +20 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domhandler/test/cases/08-extra_spaces_in_tag.json +20 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domhandler/test/cases/09-unquoted_attrib.json +20 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domhandler/test/cases/10-singular_attribute.json +15 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domhandler/test/cases/11-text_outside_tags.json +40 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domhandler/test/cases/12-text_only.json +11 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domhandler/test/cases/13-comment_in_text.json +19 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domhandler/test/cases/14-comment_in_text_in_script.json +18 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domhandler/test/cases/15-non-verbose.json +22 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domhandler/test/cases/16-normalize_whitespace.json +47 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domhandler/test/cases/17-xml_namespace.json +18 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domhandler/test/cases/18-enforce_empty_tags.json +16 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domhandler/test/cases/19-ignore_empty_tags.json +20 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domhandler/test/cases/20-template_script_tags.json +20 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domhandler/test/cases/21-conditional_comments.json +15 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domhandler/test/cases/22-lowercase_tags.json +41 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domhandler/test/cases/23-dom-lvl1.json +121 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domhandler/test/tests.js +58 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domutils/LICENSE +11 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domutils/index.js +14 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domutils/lib/helpers.js +141 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domutils/lib/legacy.js +87 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domutils/lib/manipulation.js +77 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domutils/lib/querying.js +94 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domutils/lib/stringify.js +93 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domutils/lib/traversal.js +24 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domutils/package.json +71 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domutils/readme.md +1 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domutils/test/fixture.js +6 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domutils/test/tests/helpers.js +89 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domutils/test/tests/legacy.js +119 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/domutils/test/utils.js +9 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/entities/LICENSE +11 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/entities/index.js +31 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/entities/lib/decode.js +72 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/entities/lib/decode_codepoint.js +26 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/entities/lib/encode.js +48 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/entities/maps/decode.json +1 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/entities/maps/entities.json +1 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/entities/maps/legacy.json +1 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/entities/maps/xml.json +1 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/entities/package.json +79 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/entities/readme.md +31 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/entities/test/mocha.opts +2 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/entities/test/test.js +150 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/LICENSE +18 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/README.md +15 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/duplex.js +1 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/float.patch +923 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/lib/_stream_duplex.js +89 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/lib/_stream_passthrough.js +46 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/lib/_stream_readable.js +944 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/lib/_stream_transform.js +209 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/lib/_stream_writable.js +472 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/node_modules/core-util-is/README.md +3 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/node_modules/core-util-is/float.patch +604 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/node_modules/core-util-is/lib/util.js +107 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/node_modules/core-util-is/package.json +53 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/node_modules/core-util-is/util.js +106 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/node_modules/inherits/LICENSE +16 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/node_modules/inherits/README.md +42 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/node_modules/inherits/inherits.js +1 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/node_modules/inherits/inherits_browser.js +23 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/node_modules/inherits/package.json +51 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/node_modules/inherits/test.js +25 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/node_modules/isarray/README.md +54 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/node_modules/isarray/build/build.js +209 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/node_modules/isarray/component.json +19 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/node_modules/isarray/index.js +3 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/node_modules/isarray/package.json +54 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/node_modules/string_decoder/LICENSE +20 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/node_modules/string_decoder/README.md +7 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/node_modules/string_decoder/index.js +200 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/node_modules/string_decoder/package.json +53 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/package.json +68 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/passthrough.js +1 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/readable.js +7 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/transform.js +1 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/node_modules/readable-stream/writable.js +1 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/package.json +90 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/01-events.js +9 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/02-stream.js +23 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/03-feed.js +19 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Documents/Atom_Example.xml +25 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Documents/Attributes.html +16 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Documents/Basic.html +1 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Documents/RDF_Example.xml +63 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Documents/RSS_Example.xml +48 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/01-simple.json +44 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/02-template.json +63 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/03-lowercase_tags.json +46 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/04-cdata.json +50 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/05-cdata-special.json +35 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/06-leading-lt.json +16 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/07-self-closing.json +67 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/08-implicit-close-tags.json +59 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/09-attributes.json +68 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/10-crazy-attrib.json +52 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/11-script_in_script.json +54 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/12-long-comment-end.json +20 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/13-long-cdata-end.json +22 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/14-implicit-open-tags.json +27 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/15-lt-whitespace.json +16 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/16-double_attribs.json +45 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/17-numeric_entities.json +16 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/18-legacy_entities.json +16 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/19-named_entities.json +16 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/20-xml_entities.json +16 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/21-entity_in_attribute.json +38 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/22-double_brackets.json +41 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/23-legacy_entity_fail.json +16 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/24-special_special.json +133 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/25-empty_tag_name.json +13 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/26-not-quite-closed.json +35 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/27-entities_in_attributes.json +62 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/28-cdata_in_html.json +9 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/29-comment_edge-cases.json +18 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Events/30-cdata_edge-cases.json +22 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Feeds/01-rss.js +34 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Feeds/02-atom.js +18 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Feeds/03-rdf.js +20 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Stream/01-basic.json +83 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Stream/02-RSS.json +1093 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Stream/03-Atom.json +644 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Stream/04-RDF.json +1399 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/Stream/05-Attributes.json +354 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/api.js +63 -0
- data/vendor/javascript/node_modules/jshint/node_modules/htmlparser2/test/test-helper.js +83 -0
- data/vendor/javascript/node_modules/jshint/node_modules/minimatch/LICENSE +23 -0
- data/vendor/javascript/node_modules/jshint/node_modules/minimatch/README.md +218 -0
- data/vendor/javascript/node_modules/jshint/node_modules/minimatch/minimatch.js +1061 -0
- data/vendor/javascript/node_modules/jshint/node_modules/minimatch/node_modules/lru-cache/CONTRIBUTORS +14 -0
- data/vendor/javascript/node_modules/jshint/node_modules/minimatch/node_modules/lru-cache/LICENSE +23 -0
- data/vendor/javascript/node_modules/jshint/node_modules/minimatch/node_modules/lru-cache/README.md +97 -0
- data/vendor/javascript/node_modules/jshint/node_modules/minimatch/node_modules/lru-cache/lib/lru-cache.js +252 -0
- data/vendor/javascript/node_modules/jshint/node_modules/minimatch/node_modules/lru-cache/package.json +50 -0
- data/vendor/javascript/node_modules/jshint/node_modules/minimatch/node_modules/lru-cache/test/basic.js +369 -0
- data/vendor/javascript/node_modules/jshint/node_modules/minimatch/node_modules/lru-cache/test/foreach.js +52 -0
- data/vendor/javascript/node_modules/jshint/node_modules/minimatch/node_modules/lru-cache/test/memory-leak.js +50 -0
- data/vendor/javascript/node_modules/jshint/node_modules/minimatch/node_modules/sigmund/LICENSE +27 -0
- data/vendor/javascript/node_modules/jshint/node_modules/minimatch/node_modules/sigmund/README.md +53 -0
- data/vendor/javascript/node_modules/jshint/node_modules/minimatch/node_modules/sigmund/bench.js +283 -0
- data/vendor/javascript/node_modules/jshint/node_modules/minimatch/node_modules/sigmund/package.json +58 -0
- data/vendor/javascript/node_modules/jshint/node_modules/minimatch/node_modules/sigmund/sigmund.js +39 -0
- data/vendor/javascript/node_modules/jshint/node_modules/minimatch/node_modules/sigmund/test/basic.js +24 -0
- data/vendor/javascript/node_modules/jshint/node_modules/minimatch/package.json +57 -0
- data/vendor/javascript/node_modules/jshint/node_modules/minimatch/test/basic.js +399 -0
- data/vendor/javascript/node_modules/jshint/node_modules/minimatch/test/brace-expand.js +33 -0
- data/vendor/javascript/node_modules/jshint/node_modules/minimatch/test/caching.js +14 -0
- data/vendor/javascript/node_modules/jshint/node_modules/minimatch/test/defaults.js +274 -0
- data/vendor/javascript/node_modules/jshint/node_modules/minimatch/test/extglob-ending-with-state-char.js +8 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/LICENSE +26 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/README.md +569 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/bin/shjs +51 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/global.js +3 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/make.js +47 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/package.json +61 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/scripts/generate-docs.js +21 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/scripts/run-tests.js +50 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/shell.js +157 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/src/cat.js +43 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/src/cd.js +19 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/src/chmod.js +208 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/src/common.js +203 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/src/cp.js +201 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/src/dirs.js +191 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/src/echo.js +20 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/src/error.js +10 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/src/exec.js +181 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/src/find.js +51 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/src/grep.js +52 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/src/ln.js +53 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/src/ls.js +126 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/src/mkdir.js +68 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/src/mv.js +80 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/src/popd.js +1 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/src/pushd.js +1 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/src/pwd.js +11 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/src/rm.js +145 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/src/sed.js +43 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/src/tempdir.js +56 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/src/test.js +85 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/src/to.js +29 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/src/toEnd.js +29 -0
- data/vendor/javascript/node_modules/jshint/node_modules/shelljs/src/which.js +83 -0
- data/vendor/javascript/node_modules/jshint/node_modules/strip-json-comments/cli.js +41 -0
- data/vendor/javascript/node_modules/jshint/node_modules/strip-json-comments/package.json +76 -0
- data/vendor/javascript/node_modules/jshint/node_modules/strip-json-comments/readme.md +74 -0
- data/vendor/javascript/node_modules/jshint/node_modules/strip-json-comments/strip-json-comments.js +64 -0
- data/vendor/javascript/node_modules/jshint/node_modules/underscore/LICENSE +23 -0
- data/vendor/javascript/node_modules/jshint/node_modules/underscore/README.md +22 -0
- data/vendor/javascript/node_modules/jshint/node_modules/underscore/package.json +66 -0
- data/vendor/javascript/node_modules/jshint/node_modules/underscore/underscore-min.js +6 -0
- data/vendor/javascript/node_modules/jshint/node_modules/underscore/underscore.js +1343 -0
- data/vendor/javascript/node_modules/jshint/package.json +80 -0
- data/vendor/javascript/node_modules/jshint/src/cli.js +731 -0
- data/vendor/javascript/node_modules/jshint/src/jshint.js +5023 -0
- data/vendor/javascript/node_modules/jshint/src/lex.js +1650 -0
- data/vendor/javascript/node_modules/jshint/src/messages.js +223 -0
- data/vendor/javascript/node_modules/jshint/src/platforms/rhino.js +115 -0
- data/vendor/javascript/node_modules/jshint/src/reg.js +38 -0
- data/vendor/javascript/node_modules/jshint/src/reporters/checkstyle.js +81 -0
- data/vendor/javascript/node_modules/jshint/src/reporters/default.js +34 -0
- data/vendor/javascript/node_modules/jshint/src/reporters/jslint_xml.js +57 -0
- data/vendor/javascript/node_modules/jshint/src/reporters/non_error.js +52 -0
- data/vendor/javascript/node_modules/jshint/src/state.js +28 -0
- data/vendor/javascript/node_modules/jshint/src/style.js +143 -0
- data/vendor/javascript/node_modules/jshint/src/vars.js +658 -0
- data/vendor/python/astroid/COPYING +339 -0
- data/vendor/python/astroid/COPYING.LESSER +510 -0
- data/vendor/python/astroid/ChangeLog +574 -0
- data/vendor/python/astroid/MANIFEST.in +9 -0
- data/vendor/python/astroid/README +56 -0
- data/vendor/python/astroid/README.Python3 +26 -0
- data/vendor/python/astroid/__init__.py +118 -0
- data/vendor/python/astroid/__init__.pyc +0 -0
- data/vendor/python/astroid/__pkginfo__.py +48 -0
- data/vendor/python/astroid/__pkginfo__.pyc +0 -0
- data/vendor/python/astroid/announce.txt +23 -0
- data/vendor/python/astroid/as_string.py +496 -0
- data/vendor/python/astroid/as_string.pyc +0 -0
- data/vendor/python/astroid/bases.py +618 -0
- data/vendor/python/astroid/bases.pyc +0 -0
- data/vendor/python/astroid/brain/py2gi.py +159 -0
- data/vendor/python/astroid/brain/py2gi.pyc +0 -0
- data/vendor/python/astroid/brain/py2mechanize.py +20 -0
- data/vendor/python/astroid/brain/py2mechanize.pyc +0 -0
- data/vendor/python/astroid/brain/py2qt4.py +25 -0
- data/vendor/python/astroid/brain/py2qt4.pyc +0 -0
- data/vendor/python/astroid/brain/py2stdlib.py +252 -0
- data/vendor/python/astroid/brain/py2stdlib.pyc +0 -0
- data/vendor/python/astroid/builder.py +238 -0
- data/vendor/python/astroid/builder.pyc +0 -0
- data/vendor/python/astroid/exceptions.py +51 -0
- data/vendor/python/astroid/exceptions.pyc +0 -0
- data/vendor/python/astroid/inference.py +393 -0
- data/vendor/python/astroid/inference.pyc +0 -0
- data/vendor/python/astroid/inspector.py +275 -0
- data/vendor/python/astroid/manager.py +336 -0
- data/vendor/python/astroid/manager.pyc +0 -0
- data/vendor/python/astroid/mixins.py +122 -0
- data/vendor/python/astroid/mixins.pyc +0 -0
- data/vendor/python/astroid/node_classes.py +928 -0
- data/vendor/python/astroid/node_classes.pyc +0 -0
- data/vendor/python/astroid/nodes.py +73 -0
- data/vendor/python/astroid/nodes.pyc +0 -0
- data/vendor/python/astroid/protocols.py +322 -0
- data/vendor/python/astroid/protocols.pyc +0 -0
- data/vendor/python/astroid/raw_building.py +361 -0
- data/vendor/python/astroid/raw_building.pyc +0 -0
- data/vendor/python/astroid/rebuilder.py +954 -0
- data/vendor/python/astroid/rebuilder.pyc +0 -0
- data/vendor/python/astroid/scoped_nodes.py +1118 -0
- data/vendor/python/astroid/scoped_nodes.pyc +0 -0
- data/vendor/python/astroid/setup.py +184 -0
- data/vendor/python/astroid/tox.ini +10 -0
- data/vendor/python/astroid/utils.py +236 -0
- data/vendor/python/astroid/utils.pyc +0 -0
- data/vendor/python/logilab/__init__.py +0 -0
- data/vendor/python/logilab/__init__.pyc +0 -0
- data/vendor/python/logilab/common/COPYING +339 -0
- data/vendor/python/logilab/common/COPYING.LESSER +510 -0
- data/vendor/python/logilab/common/ChangeLog +1517 -0
- data/vendor/python/logilab/common/MANIFEST.in +13 -0
- data/vendor/python/logilab/common/README +185 -0
- data/vendor/python/logilab/common/README.Python3 +29 -0
- data/vendor/python/logilab/common/__init__.py +171 -0
- data/vendor/python/logilab/common/__init__.pyc +0 -0
- data/vendor/python/logilab/common/__pkginfo__.py +53 -0
- data/vendor/python/logilab/common/__pkginfo__.pyc +0 -0
- data/vendor/python/logilab/common/announce.txt +25 -0
- data/vendor/python/logilab/common/bin/pytest +7 -0
- data/vendor/python/logilab/common/bin/pytest.bat +17 -0
- data/vendor/python/logilab/common/cache.py +114 -0
- data/vendor/python/logilab/common/changelog.py +236 -0
- data/vendor/python/logilab/common/changelog.pyc +0 -0
- data/vendor/python/logilab/common/clcommands.py +332 -0
- data/vendor/python/logilab/common/cli.py +208 -0
- data/vendor/python/logilab/common/compat.py +243 -0
- data/vendor/python/logilab/common/compat.pyc +0 -0
- data/vendor/python/logilab/common/configuration.py +1094 -0
- data/vendor/python/logilab/common/configuration.pyc +0 -0
- data/vendor/python/logilab/common/contexts.py +5 -0
- data/vendor/python/logilab/common/corbautils.py +117 -0
- data/vendor/python/logilab/common/daemon.py +100 -0
- data/vendor/python/logilab/common/date.py +333 -0
- data/vendor/python/logilab/common/dbf.py +229 -0
- data/vendor/python/logilab/common/debugger.py +210 -0
- data/vendor/python/logilab/common/decorators.py +281 -0
- data/vendor/python/logilab/common/decorators.pyc +0 -0
- data/vendor/python/logilab/common/deprecation.py +188 -0
- data/vendor/python/logilab/common/deprecation.pyc +0 -0
- data/vendor/python/logilab/common/fileutils.py +402 -0
- data/vendor/python/logilab/common/graph.py +276 -0
- data/vendor/python/logilab/common/graph.pyc +0 -0
- data/vendor/python/logilab/common/hg.py +130 -0
- data/vendor/python/logilab/common/interface.py +71 -0
- data/vendor/python/logilab/common/interface.pyc +0 -0
- data/vendor/python/logilab/common/logging_ext.py +193 -0
- data/vendor/python/logilab/common/modutils.py +695 -0
- data/vendor/python/logilab/common/modutils.pyc +0 -0
- data/vendor/python/logilab/common/optik_ext.py +391 -0
- data/vendor/python/logilab/common/optik_ext.pyc +0 -0
- data/vendor/python/logilab/common/optparser.py +90 -0
- data/vendor/python/logilab/common/proc.py +277 -0
- data/vendor/python/logilab/common/pyro_ext.py +180 -0
- data/vendor/python/logilab/common/pytest.py +1177 -0
- data/vendor/python/logilab/common/python-logilab-common.spec +184 -0
- data/vendor/python/logilab/common/registry.py +1113 -0
- data/vendor/python/logilab/common/setup.cfg +3 -0
- data/vendor/python/logilab/common/setup.py +189 -0
- data/vendor/python/logilab/common/shellutils.py +455 -0
- data/vendor/python/logilab/common/sphinx_ext.py +87 -0
- data/vendor/python/logilab/common/sphinxutils.py +122 -0
- data/vendor/python/logilab/common/table.py +925 -0
- data/vendor/python/logilab/common/tasksqueue.py +100 -0
- data/vendor/python/logilab/common/textutils.py +534 -0
- data/vendor/python/logilab/common/textutils.pyc +0 -0
- data/vendor/python/logilab/common/tree.py +369 -0
- data/vendor/python/logilab/common/tree.pyc +0 -0
- data/vendor/python/logilab/common/umessage.py +190 -0
- data/vendor/python/logilab/common/ureports/__init__.py +174 -0
- data/vendor/python/logilab/common/ureports/__init__.pyc +0 -0
- data/vendor/python/logilab/common/ureports/docbook_writer.py +139 -0
- data/vendor/python/logilab/common/ureports/html_writer.py +131 -0
- data/vendor/python/logilab/common/ureports/html_writer.pyc +0 -0
- data/vendor/python/logilab/common/ureports/nodes.py +201 -0
- data/vendor/python/logilab/common/ureports/nodes.pyc +0 -0
- data/vendor/python/logilab/common/ureports/text_writer.py +140 -0
- data/vendor/python/logilab/common/ureports/text_writer.pyc +0 -0
- data/vendor/python/logilab/common/urllib2ext.py +87 -0
- data/vendor/python/logilab/common/vcgutils.py +216 -0
- data/vendor/python/logilab/common/visitor.py +107 -0
- data/vendor/python/logilab/common/visitor.pyc +0 -0
- data/vendor/python/logilab/common/xmlrpcutils.py +131 -0
- data/vendor/python/logilab/common/xmlutils.py +61 -0
- data/vendor/python/pylint/CONTRIBUTORS.txt +38 -0
- data/vendor/python/pylint/COPYING +340 -0
- data/vendor/python/pylint/ChangeLog +1437 -0
- data/vendor/python/pylint/DEPENDS +3 -0
- data/vendor/python/pylint/MANIFEST.in +14 -0
- data/vendor/python/pylint/README +50 -0
- data/vendor/python/pylint/README.Python3 +37 -0
- data/vendor/python/pylint/__init__.py +44 -0
- data/vendor/python/pylint/__init__.pyc +0 -0
- data/vendor/python/pylint/__main__.py +3 -0
- data/vendor/python/pylint/__pkginfo__.py +74 -0
- data/vendor/python/pylint/__pkginfo__.pyc +0 -0
- data/vendor/python/pylint/bin/epylint +3 -0
- data/vendor/python/pylint/bin/epylint.bat +5 -0
- data/vendor/python/pylint/bin/pylint +3 -0
- data/vendor/python/pylint/bin/pylint-gui +3 -0
- data/vendor/python/pylint/bin/pylint-gui.bat +5 -0
- data/vendor/python/pylint/bin/pylint.bat +5 -0
- data/vendor/python/pylint/bin/pyreverse +3 -0
- data/vendor/python/pylint/bin/pyreverse.bat +5 -0
- data/vendor/python/pylint/bin/symilar +3 -0
- data/vendor/python/pylint/bin/symilar.bat +5 -0
- data/vendor/python/pylint/checkers/__init__.py +145 -0
- data/vendor/python/pylint/checkers/__init__.pyc +0 -0
- data/vendor/python/pylint/checkers/base.py +1141 -0
- data/vendor/python/pylint/checkers/base.pyc +0 -0
- data/vendor/python/pylint/checkers/classes.py +792 -0
- data/vendor/python/pylint/checkers/classes.pyc +0 -0
- data/vendor/python/pylint/checkers/design_analysis.py +367 -0
- data/vendor/python/pylint/checkers/design_analysis.pyc +0 -0
- data/vendor/python/pylint/checkers/exceptions.py +306 -0
- data/vendor/python/pylint/checkers/exceptions.pyc +0 -0
- data/vendor/python/pylint/checkers/format.py +943 -0
- data/vendor/python/pylint/checkers/format.pyc +0 -0
- data/vendor/python/pylint/checkers/imports.py +394 -0
- data/vendor/python/pylint/checkers/imports.pyc +0 -0
- data/vendor/python/pylint/checkers/logging.py +213 -0
- data/vendor/python/pylint/checkers/logging.pyc +0 -0
- data/vendor/python/pylint/checkers/misc.py +90 -0
- data/vendor/python/pylint/checkers/misc.pyc +0 -0
- data/vendor/python/pylint/checkers/newstyle.py +151 -0
- data/vendor/python/pylint/checkers/newstyle.pyc +0 -0
- data/vendor/python/pylint/checkers/raw_metrics.py +129 -0
- data/vendor/python/pylint/checkers/raw_metrics.pyc +0 -0
- data/vendor/python/pylint/checkers/similar.py +365 -0
- data/vendor/python/pylint/checkers/similar.pyc +0 -0
- data/vendor/python/pylint/checkers/stdlib.py +69 -0
- data/vendor/python/pylint/checkers/stdlib.pyc +0 -0
- data/vendor/python/pylint/checkers/strings.py +304 -0
- data/vendor/python/pylint/checkers/strings.pyc +0 -0
- data/vendor/python/pylint/checkers/typecheck.py +451 -0
- data/vendor/python/pylint/checkers/typecheck.pyc +0 -0
- data/vendor/python/pylint/checkers/utils.py +416 -0
- data/vendor/python/pylint/checkers/utils.pyc +0 -0
- data/vendor/python/pylint/checkers/variables.py +741 -0
- data/vendor/python/pylint/checkers/variables.pyc +0 -0
- data/vendor/python/pylint/config.py +156 -0
- data/vendor/python/pylint/config.pyc +0 -0
- data/vendor/python/pylint/epylint.py +175 -0
- data/vendor/python/pylint/gui.py +508 -0
- data/vendor/python/pylint/interfaces.py +72 -0
- data/vendor/python/pylint/interfaces.pyc +0 -0
- data/vendor/python/pylint/lint.py +1106 -0
- data/vendor/python/pylint/lint.pyc +0 -0
- data/vendor/python/pylint/pyreverse/__init__.py +5 -0
- data/vendor/python/pylint/pyreverse/diadefslib.py +233 -0
- data/vendor/python/pylint/pyreverse/diagrams.py +247 -0
- data/vendor/python/pylint/pyreverse/main.py +124 -0
- data/vendor/python/pylint/pyreverse/utils.py +131 -0
- data/vendor/python/pylint/pyreverse/writer.py +199 -0
- data/vendor/python/pylint/reporters/__init__.py +138 -0
- data/vendor/python/pylint/reporters/__init__.pyc +0 -0
- data/vendor/python/pylint/reporters/guireporter.py +28 -0
- data/vendor/python/pylint/reporters/guireporter.pyc +0 -0
- data/vendor/python/pylint/reporters/html.py +70 -0
- data/vendor/python/pylint/reporters/html.pyc +0 -0
- data/vendor/python/pylint/reporters/text.py +143 -0
- data/vendor/python/pylint/reporters/text.pyc +0 -0
- data/vendor/python/pylint/setup.cfg +3 -0
- data/vendor/python/pylint/setup.py +203 -0
- data/vendor/python/pylint/tox.ini +10 -0
- data/vendor/python/pylint/utils.py +744 -0
- data/vendor/python/pylint/utils.pyc +0 -0
- data/vendor/python/pylint_runner.py +22 -0
- metadata +675 -0
Binary file
|
@@ -0,0 +1,394 @@
|
|
1
|
+
# Copyright (c) 2003-2013 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
|
+
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
16
|
+
"""imports checkers for Python code"""
|
17
|
+
|
18
|
+
import sys
|
19
|
+
|
20
|
+
from logilab.common.graph import get_cycles, DotBackend
|
21
|
+
from logilab.common.modutils import get_module_part, is_standard_module
|
22
|
+
from logilab.common.ureports import VerbatimText, Paragraph
|
23
|
+
|
24
|
+
import astroid
|
25
|
+
from astroid import are_exclusive
|
26
|
+
|
27
|
+
from pylint.interfaces import IAstroidChecker
|
28
|
+
from pylint.utils import EmptyReport
|
29
|
+
from pylint.checkers import BaseChecker
|
30
|
+
from pylint.checkers.utils import check_messages
|
31
|
+
|
32
|
+
|
33
|
+
def get_first_import(node, context, name, base, level):
|
34
|
+
"""return the node where [base.]<name> is imported or None if not found
|
35
|
+
"""
|
36
|
+
fullname = '%s.%s' % (base, name) if base else name
|
37
|
+
|
38
|
+
first = None
|
39
|
+
found = False
|
40
|
+
for first in context.body:
|
41
|
+
if first is node:
|
42
|
+
continue
|
43
|
+
if first.scope() is node.scope() and first.fromlineno > node.fromlineno:
|
44
|
+
continue
|
45
|
+
if isinstance(first, astroid.Import):
|
46
|
+
if any(fullname == iname[0] for iname in first.names):
|
47
|
+
found = True
|
48
|
+
break
|
49
|
+
elif isinstance(first, astroid.From):
|
50
|
+
if level == first.level and any(
|
51
|
+
fullname == '%s.%s' % (first.modname, iname[0]) for iname in first.names):
|
52
|
+
found = True
|
53
|
+
break
|
54
|
+
if found and not are_exclusive(first, node):
|
55
|
+
return first
|
56
|
+
|
57
|
+
# utilities to represents import dependencies as tree and dot graph ###########
|
58
|
+
|
59
|
+
def make_tree_defs(mod_files_list):
|
60
|
+
"""get a list of 2-uple (module, list_of_files_which_import_this_module),
|
61
|
+
it will return a dictionary to represent this as a tree
|
62
|
+
"""
|
63
|
+
tree_defs = {}
|
64
|
+
for mod, files in mod_files_list:
|
65
|
+
node = (tree_defs, ())
|
66
|
+
for prefix in mod.split('.'):
|
67
|
+
node = node[0].setdefault(prefix, [{}, []])
|
68
|
+
node[1] += files
|
69
|
+
return tree_defs
|
70
|
+
|
71
|
+
def repr_tree_defs(data, indent_str=None):
|
72
|
+
"""return a string which represents imports as a tree"""
|
73
|
+
lines = []
|
74
|
+
nodes = data.items()
|
75
|
+
for i, (mod, (sub, files)) in enumerate(sorted(nodes, key=lambda x: x[0])):
|
76
|
+
if not files:
|
77
|
+
files = ''
|
78
|
+
else:
|
79
|
+
files = '(%s)' % ','.join(files)
|
80
|
+
if indent_str is None:
|
81
|
+
lines.append('%s %s' % (mod, files))
|
82
|
+
sub_indent_str = ' '
|
83
|
+
else:
|
84
|
+
lines.append(r'%s\-%s %s' % (indent_str, mod, files))
|
85
|
+
if i == len(nodes)-1:
|
86
|
+
sub_indent_str = '%s ' % indent_str
|
87
|
+
else:
|
88
|
+
sub_indent_str = '%s| ' % indent_str
|
89
|
+
if sub:
|
90
|
+
lines.append(repr_tree_defs(sub, sub_indent_str))
|
91
|
+
return '\n'.join(lines)
|
92
|
+
|
93
|
+
|
94
|
+
def dependencies_graph(filename, dep_info):
|
95
|
+
"""write dependencies as a dot (graphviz) file
|
96
|
+
"""
|
97
|
+
done = {}
|
98
|
+
printer = DotBackend(filename[:-4], rankdir='LR')
|
99
|
+
printer.emit('URL="." node[shape="box"]')
|
100
|
+
for modname, dependencies in sorted(dep_info.iteritems()):
|
101
|
+
done[modname] = 1
|
102
|
+
printer.emit_node(modname)
|
103
|
+
for modname in dependencies:
|
104
|
+
if modname not in done:
|
105
|
+
done[modname] = 1
|
106
|
+
printer.emit_node(modname)
|
107
|
+
for depmodname, dependencies in sorted(dep_info.iteritems()):
|
108
|
+
for modname in dependencies:
|
109
|
+
printer.emit_edge(modname, depmodname)
|
110
|
+
printer.generate(filename)
|
111
|
+
|
112
|
+
|
113
|
+
def make_graph(filename, dep_info, sect, gtype):
|
114
|
+
"""generate a dependencies graph and add some information about it in the
|
115
|
+
report's section
|
116
|
+
"""
|
117
|
+
dependencies_graph(filename, dep_info)
|
118
|
+
sect.append(Paragraph('%simports graph has been written to %s'
|
119
|
+
% (gtype, filename)))
|
120
|
+
|
121
|
+
|
122
|
+
# the import checker itself ###################################################
|
123
|
+
|
124
|
+
MSGS = {
|
125
|
+
'F0401': ('Unable to import %s',
|
126
|
+
'import-error',
|
127
|
+
'Used when pylint has been unable to import a module.'),
|
128
|
+
'R0401': ('Cyclic import (%s)',
|
129
|
+
'cyclic-import',
|
130
|
+
'Used when a cyclic import between two or more modules is \
|
131
|
+
detected.'),
|
132
|
+
|
133
|
+
'W0401': ('Wildcard import %s',
|
134
|
+
'wildcard-import',
|
135
|
+
'Used when `from module import *` is detected.'),
|
136
|
+
'W0402': ('Uses of a deprecated module %r',
|
137
|
+
'deprecated-module',
|
138
|
+
'Used a module marked as deprecated is imported.'),
|
139
|
+
'W0403': ('Relative import %r, should be %r',
|
140
|
+
'relative-import',
|
141
|
+
'Used when an import relative to the package directory is \
|
142
|
+
detected.'),
|
143
|
+
'W0404': ('Reimport %r (imported line %s)',
|
144
|
+
'reimported',
|
145
|
+
'Used when a module is reimported multiple times.'),
|
146
|
+
'W0406': ('Module import itself',
|
147
|
+
'import-self',
|
148
|
+
'Used when a module is importing itself.'),
|
149
|
+
|
150
|
+
'W0410': ('__future__ import is not the first non docstring statement',
|
151
|
+
'misplaced-future',
|
152
|
+
'Python 2.5 and greater require __future__ import to be the \
|
153
|
+
first non docstring statement in the module.',
|
154
|
+
{'maxversion': (3, 0)}),
|
155
|
+
}
|
156
|
+
|
157
|
+
class ImportsChecker(BaseChecker):
|
158
|
+
"""checks for
|
159
|
+
* external modules dependencies
|
160
|
+
* relative / wildcard imports
|
161
|
+
* cyclic imports
|
162
|
+
* uses of deprecated modules
|
163
|
+
"""
|
164
|
+
|
165
|
+
__implements__ = IAstroidChecker
|
166
|
+
|
167
|
+
name = 'imports'
|
168
|
+
msgs = MSGS
|
169
|
+
priority = -2
|
170
|
+
|
171
|
+
if sys.version_info < (3,):
|
172
|
+
deprecated_modules = ('regsub', 'TERMIOS', 'Bastion', 'rexec')
|
173
|
+
else:
|
174
|
+
deprecated_modules = ('stringprep', 'optparse')
|
175
|
+
options = (('deprecated-modules',
|
176
|
+
{'default' : deprecated_modules,
|
177
|
+
'type' : 'csv',
|
178
|
+
'metavar' : '<modules>',
|
179
|
+
'help' : 'Deprecated modules which should not be used, \
|
180
|
+
separated by a comma'}
|
181
|
+
),
|
182
|
+
('import-graph',
|
183
|
+
{'default' : '',
|
184
|
+
'type' : 'string',
|
185
|
+
'metavar' : '<file.dot>',
|
186
|
+
'help' : 'Create a graph of every (i.e. internal and \
|
187
|
+
external) dependencies in the given file (report RP0402 must not be disabled)'}
|
188
|
+
),
|
189
|
+
('ext-import-graph',
|
190
|
+
{'default' : '',
|
191
|
+
'type' : 'string',
|
192
|
+
'metavar' : '<file.dot>',
|
193
|
+
'help' : 'Create a graph of external dependencies in the \
|
194
|
+
given file (report RP0402 must not be disabled)'}
|
195
|
+
),
|
196
|
+
('int-import-graph',
|
197
|
+
{'default' : '',
|
198
|
+
'type' : 'string',
|
199
|
+
'metavar' : '<file.dot>',
|
200
|
+
'help' : 'Create a graph of internal dependencies in the \
|
201
|
+
given file (report RP0402 must not be disabled)'}
|
202
|
+
),
|
203
|
+
|
204
|
+
)
|
205
|
+
|
206
|
+
def __init__(self, linter=None):
|
207
|
+
BaseChecker.__init__(self, linter)
|
208
|
+
self.stats = None
|
209
|
+
self.import_graph = None
|
210
|
+
self.__int_dep_info = self.__ext_dep_info = None
|
211
|
+
self.reports = (('RP0401', 'External dependencies',
|
212
|
+
self.report_external_dependencies),
|
213
|
+
('RP0402', 'Modules dependencies graph',
|
214
|
+
self.report_dependencies_graph),
|
215
|
+
)
|
216
|
+
|
217
|
+
def open(self):
|
218
|
+
"""called before visiting project (i.e set of modules)"""
|
219
|
+
self.linter.add_stats(dependencies={})
|
220
|
+
self.linter.add_stats(cycles=[])
|
221
|
+
self.stats = self.linter.stats
|
222
|
+
self.import_graph = {}
|
223
|
+
|
224
|
+
def close(self):
|
225
|
+
"""called before visiting project (i.e set of modules)"""
|
226
|
+
# don't try to compute cycles if the associated message is disabled
|
227
|
+
if self.linter.is_message_enabled('cyclic-import'):
|
228
|
+
for cycle in get_cycles(self.import_graph):
|
229
|
+
self.add_message('cyclic-import', args=' -> '.join(cycle))
|
230
|
+
|
231
|
+
def visit_import(self, node):
|
232
|
+
"""triggered when an import statement is seen"""
|
233
|
+
modnode = node.root()
|
234
|
+
for name, _ in node.names:
|
235
|
+
importedmodnode = self.get_imported_module(modnode, node, name)
|
236
|
+
if importedmodnode is None:
|
237
|
+
continue
|
238
|
+
self._check_relative_import(modnode, node, importedmodnode, name)
|
239
|
+
self._add_imported_module(node, importedmodnode.name)
|
240
|
+
self._check_deprecated_module(node, name)
|
241
|
+
self._check_reimport(node, name)
|
242
|
+
|
243
|
+
# TODO This appears to be the list of all messages of the checker...
|
244
|
+
# @check_messages('W0410', 'W0401', 'W0403', 'W0402', 'W0404', 'W0406', 'F0401')
|
245
|
+
@check_messages(*(MSGS.keys()))
|
246
|
+
def visit_from(self, node):
|
247
|
+
"""triggered when a from statement is seen"""
|
248
|
+
basename = node.modname
|
249
|
+
if basename == '__future__':
|
250
|
+
# check if this is the first non-docstring statement in the module
|
251
|
+
prev = node.previous_sibling()
|
252
|
+
if prev:
|
253
|
+
# consecutive future statements are possible
|
254
|
+
if not (isinstance(prev, astroid.From)
|
255
|
+
and prev.modname == '__future__'):
|
256
|
+
self.add_message('misplaced-future', node=node)
|
257
|
+
return
|
258
|
+
for name, _ in node.names:
|
259
|
+
if name == '*':
|
260
|
+
self.add_message('wildcard-import', args=basename, node=node)
|
261
|
+
modnode = node.root()
|
262
|
+
importedmodnode = self.get_imported_module(modnode, node, basename)
|
263
|
+
if importedmodnode is None:
|
264
|
+
return
|
265
|
+
self._check_relative_import(modnode, node, importedmodnode, basename)
|
266
|
+
self._check_deprecated_module(node, basename)
|
267
|
+
for name, _ in node.names:
|
268
|
+
if name != '*':
|
269
|
+
self._add_imported_module(node, '%s.%s' % (importedmodnode.name, name))
|
270
|
+
self._check_reimport(node, name, basename, node.level)
|
271
|
+
|
272
|
+
def get_imported_module(self, modnode, importnode, modname):
|
273
|
+
try:
|
274
|
+
return importnode.do_import_module(modname)
|
275
|
+
except astroid.InferenceError, ex:
|
276
|
+
if str(ex) != modname:
|
277
|
+
args = '%r (%s)' % (modname, ex)
|
278
|
+
else:
|
279
|
+
args = repr(modname)
|
280
|
+
self.add_message("import-error", args=args, node=importnode)
|
281
|
+
|
282
|
+
def _check_relative_import(self, modnode, importnode, importedmodnode,
|
283
|
+
importedasname):
|
284
|
+
"""check relative import. node is either an Import or From node, modname
|
285
|
+
the imported module name.
|
286
|
+
"""
|
287
|
+
if not self.linter.is_message_enabled('relative-import'):
|
288
|
+
return
|
289
|
+
if importedmodnode.file is None:
|
290
|
+
return False # built-in module
|
291
|
+
if modnode is importedmodnode:
|
292
|
+
return False # module importing itself
|
293
|
+
if modnode.absolute_import_activated() or getattr(importnode, 'level', None):
|
294
|
+
return False
|
295
|
+
if importedmodnode.name != importedasname:
|
296
|
+
# this must be a relative import...
|
297
|
+
self.add_message('relative-import', args=(importedasname, importedmodnode.name),
|
298
|
+
node=importnode)
|
299
|
+
|
300
|
+
def _add_imported_module(self, node, importedmodname):
|
301
|
+
"""notify an imported module, used to analyze dependencies"""
|
302
|
+
importedmodname = get_module_part(importedmodname)
|
303
|
+
context_name = node.root().name
|
304
|
+
if context_name == importedmodname:
|
305
|
+
# module importing itself !
|
306
|
+
self.add_message('import-self', node=node)
|
307
|
+
elif not is_standard_module(importedmodname):
|
308
|
+
# handle dependencies
|
309
|
+
importedmodnames = self.stats['dependencies'].setdefault(
|
310
|
+
importedmodname, set())
|
311
|
+
if not context_name in importedmodnames:
|
312
|
+
importedmodnames.add(context_name)
|
313
|
+
# update import graph
|
314
|
+
mgraph = self.import_graph.setdefault(context_name, set())
|
315
|
+
if not importedmodname in mgraph:
|
316
|
+
mgraph.add(importedmodname)
|
317
|
+
|
318
|
+
def _check_deprecated_module(self, node, mod_path):
|
319
|
+
"""check if the module is deprecated"""
|
320
|
+
for mod_name in self.config.deprecated_modules:
|
321
|
+
if mod_path == mod_name or mod_path.startswith(mod_name + '.'):
|
322
|
+
self.add_message('deprecated-module', node=node, args=mod_path)
|
323
|
+
|
324
|
+
def _check_reimport(self, node, name, basename=None, level=None):
|
325
|
+
"""check if the import is necessary (i.e. not already done)"""
|
326
|
+
if not self.linter.is_message_enabled('reimported'):
|
327
|
+
return
|
328
|
+
frame = node.frame()
|
329
|
+
root = node.root()
|
330
|
+
contexts = [(frame, level)]
|
331
|
+
if root is not frame:
|
332
|
+
contexts.append((root, None))
|
333
|
+
for context, level in contexts:
|
334
|
+
first = get_first_import(node, context, name, basename, level)
|
335
|
+
if first is not None:
|
336
|
+
self.add_message('reimported', node=node,
|
337
|
+
args=(name, first.fromlineno))
|
338
|
+
|
339
|
+
|
340
|
+
def report_external_dependencies(self, sect, _, dummy):
|
341
|
+
"""return a verbatim layout for displaying dependencies"""
|
342
|
+
dep_info = make_tree_defs(self._external_dependencies_info().iteritems())
|
343
|
+
if not dep_info:
|
344
|
+
raise EmptyReport()
|
345
|
+
tree_str = repr_tree_defs(dep_info)
|
346
|
+
sect.append(VerbatimText(tree_str))
|
347
|
+
|
348
|
+
def report_dependencies_graph(self, sect, _, dummy):
|
349
|
+
"""write dependencies as a dot (graphviz) file"""
|
350
|
+
dep_info = self.stats['dependencies']
|
351
|
+
if not dep_info or not (self.config.import_graph
|
352
|
+
or self.config.ext_import_graph
|
353
|
+
or self.config.int_import_graph):
|
354
|
+
raise EmptyReport()
|
355
|
+
filename = self.config.import_graph
|
356
|
+
if filename:
|
357
|
+
make_graph(filename, dep_info, sect, '')
|
358
|
+
filename = self.config.ext_import_graph
|
359
|
+
if filename:
|
360
|
+
make_graph(filename, self._external_dependencies_info(),
|
361
|
+
sect, 'external ')
|
362
|
+
filename = self.config.int_import_graph
|
363
|
+
if filename:
|
364
|
+
make_graph(filename, self._internal_dependencies_info(),
|
365
|
+
sect, 'internal ')
|
366
|
+
|
367
|
+
def _external_dependencies_info(self):
|
368
|
+
"""return cached external dependencies information or build and
|
369
|
+
cache them
|
370
|
+
"""
|
371
|
+
if self.__ext_dep_info is None:
|
372
|
+
package = self.linter.base_name
|
373
|
+
self.__ext_dep_info = result = {}
|
374
|
+
for importee, importers in self.stats['dependencies'].iteritems():
|
375
|
+
if not importee.startswith(package):
|
376
|
+
result[importee] = importers
|
377
|
+
return self.__ext_dep_info
|
378
|
+
|
379
|
+
def _internal_dependencies_info(self):
|
380
|
+
"""return cached internal dependencies information or build and
|
381
|
+
cache them
|
382
|
+
"""
|
383
|
+
if self.__int_dep_info is None:
|
384
|
+
package = self.linter.base_name
|
385
|
+
self.__int_dep_info = result = {}
|
386
|
+
for importee, importers in self.stats['dependencies'].iteritems():
|
387
|
+
if importee.startswith(package):
|
388
|
+
result[importee] = importers
|
389
|
+
return self.__int_dep_info
|
390
|
+
|
391
|
+
|
392
|
+
def register(linter):
|
393
|
+
"""required method to auto register this checker """
|
394
|
+
linter.register_checker(ImportsChecker(linter))
|
Binary file
|
@@ -0,0 +1,213 @@
|
|
1
|
+
# Copyright (c) 2009-2010 Google, Inc.
|
2
|
+
# This program is free software; you can redistribute it and/or modify it under
|
3
|
+
# the terms of the GNU General Public License as published by the Free Software
|
4
|
+
# Foundation; either version 2 of the License, or (at your option) any later
|
5
|
+
# version.
|
6
|
+
#
|
7
|
+
# This program is distributed in the hope that it will be useful, but WITHOUT
|
8
|
+
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
9
|
+
# FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
10
|
+
#
|
11
|
+
# You should have received a copy of the GNU General Public License along with
|
12
|
+
# this program; if not, write to the Free Software Foundation, Inc.,
|
13
|
+
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
14
|
+
"""checker for use of Python logging
|
15
|
+
"""
|
16
|
+
|
17
|
+
import astroid
|
18
|
+
from pylint import checkers
|
19
|
+
from pylint import interfaces
|
20
|
+
from pylint.checkers import utils
|
21
|
+
from pylint.checkers.utils import check_messages
|
22
|
+
|
23
|
+
MSGS = {
|
24
|
+
'W1201': ('Specify string format arguments as logging function parameters',
|
25
|
+
'logging-not-lazy',
|
26
|
+
'Used when a logging statement has a call form of '
|
27
|
+
'"logging.<logging method>(format_string % (format_args...))". '
|
28
|
+
'Such calls should leave string interpolation to the logging '
|
29
|
+
'method itself and be written '
|
30
|
+
'"logging.<logging method>(format_string, format_args...)" '
|
31
|
+
'so that the program may avoid incurring the cost of the '
|
32
|
+
'interpolation in those cases in which no message will be '
|
33
|
+
'logged. For more, see '
|
34
|
+
'http://www.python.org/dev/peps/pep-0282/.'),
|
35
|
+
'E1200': ('Unsupported logging format character %r (%#02x) at index %d',
|
36
|
+
'logging-unsupported-format',
|
37
|
+
'Used when an unsupported format character is used in a logging\
|
38
|
+
statement format string.'),
|
39
|
+
'E1201': ('Logging format string ends in middle of conversion specifier',
|
40
|
+
'logging-format-truncated',
|
41
|
+
'Used when a logging statement format string terminates before\
|
42
|
+
the end of a conversion specifier.'),
|
43
|
+
'E1205': ('Too many arguments for logging format string',
|
44
|
+
'logging-too-many-args',
|
45
|
+
'Used when a logging format string is given too few arguments.'),
|
46
|
+
'E1206': ('Not enough arguments for logging format string',
|
47
|
+
'logging-too-few-args',
|
48
|
+
'Used when a logging format string is given too many arguments'),
|
49
|
+
}
|
50
|
+
|
51
|
+
|
52
|
+
CHECKED_CONVENIENCE_FUNCTIONS = set([
|
53
|
+
'critical', 'debug', 'error', 'exception', 'fatal', 'info', 'warn',
|
54
|
+
'warning'])
|
55
|
+
|
56
|
+
|
57
|
+
class LoggingChecker(checkers.BaseChecker):
|
58
|
+
"""Checks use of the logging module."""
|
59
|
+
|
60
|
+
__implements__ = interfaces.IAstroidChecker
|
61
|
+
name = 'logging'
|
62
|
+
msgs = MSGS
|
63
|
+
|
64
|
+
options = (('logging-modules',
|
65
|
+
{'default' : ('logging',),
|
66
|
+
'type' : 'csv',
|
67
|
+
'metavar' : '<comma separated list>',
|
68
|
+
'help' : ('Logging modules to check that the string format '
|
69
|
+
'arguments are in logging function parameter format')}
|
70
|
+
),
|
71
|
+
)
|
72
|
+
|
73
|
+
def visit_module(self, unused_node):
|
74
|
+
"""Clears any state left in this checker from last module checked."""
|
75
|
+
# The code being checked can just as easily "import logging as foo",
|
76
|
+
# so it is necessary to process the imports and store in this field
|
77
|
+
# what name the logging module is actually given.
|
78
|
+
self._logging_names = set()
|
79
|
+
logging_mods = self.config.logging_modules
|
80
|
+
|
81
|
+
self._logging_modules = set(logging_mods)
|
82
|
+
self._from_imports = {}
|
83
|
+
for logging_mod in logging_mods:
|
84
|
+
parts = logging_mod.rsplit('.', 1)
|
85
|
+
if len(parts) > 1:
|
86
|
+
self._from_imports[parts[0]] = parts[1]
|
87
|
+
|
88
|
+
def visit_from(self, node):
|
89
|
+
"""Checks to see if a module uses a non-Python logging module."""
|
90
|
+
try:
|
91
|
+
logging_name = self._from_imports[node.modname]
|
92
|
+
for module, as_name in node.names:
|
93
|
+
if module == logging_name:
|
94
|
+
self._logging_names.add(as_name or module)
|
95
|
+
except KeyError:
|
96
|
+
pass
|
97
|
+
|
98
|
+
def visit_import(self, node):
|
99
|
+
"""Checks to see if this module uses Python's built-in logging."""
|
100
|
+
for module, as_name in node.names:
|
101
|
+
if module in self._logging_modules:
|
102
|
+
self._logging_names.add(as_name or module)
|
103
|
+
|
104
|
+
@check_messages(*(MSGS.keys()))
|
105
|
+
def visit_callfunc(self, node):
|
106
|
+
"""Checks calls to logging methods."""
|
107
|
+
def is_logging_name():
|
108
|
+
return (isinstance(node.func, astroid.Getattr) and
|
109
|
+
isinstance(node.func.expr, astroid.Name) and
|
110
|
+
node.func.expr.name in self._logging_names)
|
111
|
+
|
112
|
+
def is_logger_class():
|
113
|
+
try:
|
114
|
+
for inferred in node.func.infer():
|
115
|
+
if isinstance(inferred, astroid.BoundMethod):
|
116
|
+
parent = inferred._proxied.parent
|
117
|
+
if (isinstance(parent, astroid.Class) and
|
118
|
+
(parent.qname() == 'logging.Logger' or
|
119
|
+
any(ancestor.qname() == 'logging.Logger'
|
120
|
+
for ancestor in parent.ancestors()))):
|
121
|
+
return True, inferred._proxied.name
|
122
|
+
except astroid.exceptions.InferenceError:
|
123
|
+
pass
|
124
|
+
return False, None
|
125
|
+
|
126
|
+
if is_logging_name():
|
127
|
+
name = node.func.attrname
|
128
|
+
else:
|
129
|
+
result, name = is_logger_class()
|
130
|
+
if not result:
|
131
|
+
return
|
132
|
+
self._check_log_method(node, name)
|
133
|
+
|
134
|
+
def _check_log_method(self, node, name):
|
135
|
+
"""Checks calls to logging.log(level, format, *format_args)."""
|
136
|
+
if name == 'log':
|
137
|
+
if node.starargs or node.kwargs or len(node.args) < 2:
|
138
|
+
# Either a malformed call, star args, or double-star args. Beyond
|
139
|
+
# the scope of this checker.
|
140
|
+
return
|
141
|
+
format_pos = 1
|
142
|
+
elif name in CHECKED_CONVENIENCE_FUNCTIONS:
|
143
|
+
if node.starargs or node.kwargs or not node.args:
|
144
|
+
# Either no args, star args, or double-star args. Beyond the
|
145
|
+
# scope of this checker.
|
146
|
+
return
|
147
|
+
format_pos = 0
|
148
|
+
else:
|
149
|
+
return
|
150
|
+
|
151
|
+
if isinstance(node.args[format_pos], astroid.BinOp) and node.args[format_pos].op == '%':
|
152
|
+
self.add_message('logging-not-lazy', node=node)
|
153
|
+
elif isinstance(node.args[format_pos], astroid.Const):
|
154
|
+
self._check_format_string(node, format_pos)
|
155
|
+
|
156
|
+
def _check_format_string(self, node, format_arg):
|
157
|
+
"""Checks that format string tokens match the supplied arguments.
|
158
|
+
|
159
|
+
Args:
|
160
|
+
node: AST node to be checked.
|
161
|
+
format_arg: Index of the format string in the node arguments.
|
162
|
+
"""
|
163
|
+
num_args = _count_supplied_tokens(node.args[format_arg + 1:])
|
164
|
+
if not num_args:
|
165
|
+
# If no args were supplied, then all format strings are valid -
|
166
|
+
# don't check any further.
|
167
|
+
return
|
168
|
+
format_string = node.args[format_arg].value
|
169
|
+
if not isinstance(format_string, basestring):
|
170
|
+
# If the log format is constant non-string (e.g. logging.debug(5)),
|
171
|
+
# ensure there are no arguments.
|
172
|
+
required_num_args = 0
|
173
|
+
else:
|
174
|
+
try:
|
175
|
+
keyword_args, required_num_args = \
|
176
|
+
utils.parse_format_string(format_string)
|
177
|
+
if keyword_args:
|
178
|
+
# Keyword checking on logging strings is complicated by
|
179
|
+
# special keywords - out of scope.
|
180
|
+
return
|
181
|
+
except utils.UnsupportedFormatCharacter, ex:
|
182
|
+
char = format_string[ex.index]
|
183
|
+
self.add_message('logging-unsupported-format', node=node,
|
184
|
+
args=(char, ord(char), ex.index))
|
185
|
+
return
|
186
|
+
except utils.IncompleteFormatString:
|
187
|
+
self.add_message('logging-format-truncated', node=node)
|
188
|
+
return
|
189
|
+
if num_args > required_num_args:
|
190
|
+
self.add_message('logging-too-many-args', node=node)
|
191
|
+
elif num_args < required_num_args:
|
192
|
+
self.add_message('logging-too-few-args', node=node)
|
193
|
+
|
194
|
+
|
195
|
+
def _count_supplied_tokens(args):
|
196
|
+
"""Counts the number of tokens in an args list.
|
197
|
+
|
198
|
+
The Python log functions allow for special keyword arguments: func,
|
199
|
+
exc_info and extra. To handle these cases correctly, we only count
|
200
|
+
arguments that aren't keywords.
|
201
|
+
|
202
|
+
Args:
|
203
|
+
args: List of AST nodes that are arguments for a log format string.
|
204
|
+
|
205
|
+
Returns:
|
206
|
+
Number of AST nodes that aren't keywords.
|
207
|
+
"""
|
208
|
+
return sum(1 for arg in args if not isinstance(arg, astroid.Keyword))
|
209
|
+
|
210
|
+
|
211
|
+
def register(linter):
|
212
|
+
"""Required method to auto-register this checker."""
|
213
|
+
linter.register_checker(LoggingChecker(linter))
|