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,90 @@
|
|
1
|
+
# pylint: disable=W0511
|
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
|
+
""" Copyright (c) 2000-2010 LOGILAB S.A. (Paris, FRANCE).
|
15
|
+
http://www.logilab.fr/ -- mailto:contact@logilab.fr
|
16
|
+
|
17
|
+
Check source code is ascii only or has an encoding declaration (PEP 263)
|
18
|
+
"""
|
19
|
+
|
20
|
+
import re
|
21
|
+
|
22
|
+
from pylint.interfaces import IRawChecker
|
23
|
+
from pylint.checkers import BaseChecker
|
24
|
+
|
25
|
+
|
26
|
+
MSGS = {
|
27
|
+
'W0511': ('%s',
|
28
|
+
'fixme',
|
29
|
+
'Used when a warning note as FIXME or XXX is detected.'),
|
30
|
+
'W0512': ('Cannot decode using encoding "%s", unexpected byte at position %d',
|
31
|
+
'invalid-encoded-data',
|
32
|
+
'Used when a source line cannot be decoded using the specified '
|
33
|
+
'source file encoding.',
|
34
|
+
{'maxversion': (3, 0)}),
|
35
|
+
}
|
36
|
+
|
37
|
+
|
38
|
+
class EncodingChecker(BaseChecker):
|
39
|
+
"""checks for:
|
40
|
+
* warning notes in the code like FIXME, XXX
|
41
|
+
* encoding issues.
|
42
|
+
"""
|
43
|
+
__implements__ = IRawChecker
|
44
|
+
|
45
|
+
# configuration section name
|
46
|
+
name = 'miscellaneous'
|
47
|
+
msgs = MSGS
|
48
|
+
|
49
|
+
options = (('notes',
|
50
|
+
{'type' : 'csv', 'metavar' : '<comma separated values>',
|
51
|
+
'default' : ('FIXME', 'XXX', 'TODO'),
|
52
|
+
'help' : 'List of note tags to take in consideration, \
|
53
|
+
separated by a comma.'
|
54
|
+
}),
|
55
|
+
)
|
56
|
+
|
57
|
+
def _check_note(self, notes, lineno, line):
|
58
|
+
match = notes.search(line)
|
59
|
+
if match:
|
60
|
+
self.add_message('fixme', args=line[match.start():-1], line=lineno)
|
61
|
+
|
62
|
+
def _check_encoding(self, lineno, line, file_encoding):
|
63
|
+
try:
|
64
|
+
return unicode(line, file_encoding)
|
65
|
+
except UnicodeDecodeError, ex:
|
66
|
+
self.add_message('invalid-encoded-data', line=lineno,
|
67
|
+
args=(file_encoding, ex.args[2]))
|
68
|
+
|
69
|
+
def process_module(self, module):
|
70
|
+
"""inspect the source file to find encoding problem or fixmes like
|
71
|
+
notes
|
72
|
+
"""
|
73
|
+
stream = module.file_stream
|
74
|
+
stream.seek(0) # XXX may be removed with astroid > 0.23
|
75
|
+
if self.config.notes:
|
76
|
+
notes = re.compile('|'.join(self.config.notes))
|
77
|
+
else:
|
78
|
+
notes = None
|
79
|
+
if module.file_encoding:
|
80
|
+
encoding = module.file_encoding
|
81
|
+
else:
|
82
|
+
encoding = 'ascii'
|
83
|
+
for lineno, line in enumerate(stream):
|
84
|
+
line = self._check_encoding(lineno+1, line, encoding)
|
85
|
+
if line is not None and notes:
|
86
|
+
self._check_note(notes, lineno+1, line)
|
87
|
+
|
88
|
+
def register(linter):
|
89
|
+
"""required method to auto register this checker"""
|
90
|
+
linter.register_checker(EncodingChecker(linter))
|
Binary file
|
@@ -0,0 +1,151 @@
|
|
1
|
+
# Copyright (c) 2005-2014 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
|
+
"""check for new / old style related problems
|
17
|
+
"""
|
18
|
+
import sys
|
19
|
+
|
20
|
+
import astroid
|
21
|
+
|
22
|
+
from pylint.interfaces import IAstroidChecker
|
23
|
+
from pylint.checkers import BaseChecker
|
24
|
+
from pylint.checkers.utils import check_messages
|
25
|
+
|
26
|
+
MSGS = {
|
27
|
+
'E1001': ('Use of __slots__ on an old style class',
|
28
|
+
'slots-on-old-class',
|
29
|
+
'Used when an old style class uses the __slots__ attribute.',
|
30
|
+
{'maxversion': (3, 0)}),
|
31
|
+
'E1002': ('Use of super on an old style class',
|
32
|
+
'super-on-old-class',
|
33
|
+
'Used when an old style class uses the super builtin.',
|
34
|
+
{'maxversion': (3, 0)}),
|
35
|
+
'E1003': ('Bad first argument %r given to super()',
|
36
|
+
'bad-super-call',
|
37
|
+
'Used when another argument than the current class is given as \
|
38
|
+
first argument of the super builtin.'),
|
39
|
+
'E1004': ('Missing argument to super()',
|
40
|
+
'missing-super-argument',
|
41
|
+
'Used when the super builtin didn\'t receive an \
|
42
|
+
argument.',
|
43
|
+
{'maxversion': (3, 0)}),
|
44
|
+
'W1001': ('Use of "property" on an old style class',
|
45
|
+
'property-on-old-class',
|
46
|
+
'Used when PyLint detect the use of the builtin "property" \
|
47
|
+
on an old style class while this is relying on new style \
|
48
|
+
classes features.',
|
49
|
+
{'maxversion': (3, 0)}),
|
50
|
+
'C1001': ('Old-style class defined.',
|
51
|
+
'old-style-class',
|
52
|
+
'Used when a class is defined that does not inherit from another'
|
53
|
+
'class and does not inherit explicitly from "object".',
|
54
|
+
{'maxversion': (3, 0)})
|
55
|
+
}
|
56
|
+
|
57
|
+
|
58
|
+
class NewStyleConflictChecker(BaseChecker):
|
59
|
+
"""checks for usage of new style capabilities on old style classes and
|
60
|
+
other new/old styles conflicts problems
|
61
|
+
* use of property, __slots__, super
|
62
|
+
* "super" usage
|
63
|
+
"""
|
64
|
+
|
65
|
+
__implements__ = (IAstroidChecker,)
|
66
|
+
|
67
|
+
# configuration section name
|
68
|
+
name = 'newstyle'
|
69
|
+
# messages
|
70
|
+
msgs = MSGS
|
71
|
+
priority = -2
|
72
|
+
# configuration options
|
73
|
+
options = ()
|
74
|
+
|
75
|
+
@check_messages('slots-on-old-class', 'old-style-class')
|
76
|
+
def visit_class(self, node):
|
77
|
+
"""check __slots__ usage
|
78
|
+
"""
|
79
|
+
if '__slots__' in node and not node.newstyle:
|
80
|
+
self.add_message('slots-on-old-class', node=node)
|
81
|
+
# The node type could be class, exception, metaclass, or
|
82
|
+
# interface. Presumably, the non-class-type nodes would always
|
83
|
+
# have an explicit base class anyway.
|
84
|
+
if not node.bases and node.type == 'class':
|
85
|
+
self.add_message('old-style-class', node=node)
|
86
|
+
|
87
|
+
@check_messages('property-on-old-class')
|
88
|
+
def visit_callfunc(self, node):
|
89
|
+
"""check property usage"""
|
90
|
+
parent = node.parent.frame()
|
91
|
+
if (isinstance(parent, astroid.Class) and
|
92
|
+
not parent.newstyle and
|
93
|
+
isinstance(node.func, astroid.Name)):
|
94
|
+
name = node.func.name
|
95
|
+
if name == 'property':
|
96
|
+
self.add_message('property-on-old-class', node=node)
|
97
|
+
|
98
|
+
@check_messages('super-on-old-class', 'bad-super-call', 'missing-super-argument')
|
99
|
+
def visit_function(self, node):
|
100
|
+
"""check use of super"""
|
101
|
+
# ignore actual functions or method within a new style class
|
102
|
+
if not node.is_method():
|
103
|
+
return
|
104
|
+
klass = node.parent.frame()
|
105
|
+
for stmt in node.nodes_of_class(astroid.CallFunc):
|
106
|
+
expr = stmt.func
|
107
|
+
if not isinstance(expr, astroid.Getattr):
|
108
|
+
continue
|
109
|
+
call = expr.expr
|
110
|
+
# skip the test if using super
|
111
|
+
if isinstance(call, astroid.CallFunc) and \
|
112
|
+
isinstance(call.func, astroid.Name) and \
|
113
|
+
call.func.name == 'super':
|
114
|
+
if not klass.newstyle:
|
115
|
+
# super should not be used on an old style class
|
116
|
+
self.add_message('super-on-old-class', node=node)
|
117
|
+
else:
|
118
|
+
# super first arg should be the class
|
119
|
+
if not call.args and sys.version_info[0] == 3:
|
120
|
+
# unless Python 3
|
121
|
+
continue
|
122
|
+
|
123
|
+
try:
|
124
|
+
supcls = (call.args and call.args[0].infer().next()
|
125
|
+
or None)
|
126
|
+
except astroid.InferenceError:
|
127
|
+
continue
|
128
|
+
|
129
|
+
if supcls is None:
|
130
|
+
self.add_message('missing-super-argument', node=call)
|
131
|
+
continue
|
132
|
+
|
133
|
+
if klass is not supcls:
|
134
|
+
name = None
|
135
|
+
# if supcls is not YES, then supcls was infered
|
136
|
+
# and use its name. Otherwise, try to look
|
137
|
+
# for call.args[0].name
|
138
|
+
if supcls is not astroid.YES:
|
139
|
+
name = supcls.name
|
140
|
+
else:
|
141
|
+
if hasattr(call.args[0], 'name'):
|
142
|
+
name = call.args[0].name
|
143
|
+
if name is not None:
|
144
|
+
self.add_message('bad-super-call',
|
145
|
+
node=call,
|
146
|
+
args=(name, ))
|
147
|
+
|
148
|
+
|
149
|
+
def register(linter):
|
150
|
+
"""required method to auto register this checker """
|
151
|
+
linter.register_checker(NewStyleConflictChecker(linter))
|
Binary file
|
@@ -0,0 +1,129 @@
|
|
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
|
+
""" Copyright (c) 2003-2010 LOGILAB S.A. (Paris, FRANCE).
|
17
|
+
http://www.logilab.fr/ -- mailto:contact@logilab.fr
|
18
|
+
|
19
|
+
Raw metrics checker
|
20
|
+
"""
|
21
|
+
|
22
|
+
import tokenize
|
23
|
+
|
24
|
+
# pylint now requires pylint >= 2.2, so this is no longer necessary
|
25
|
+
#if not hasattr(tokenize, 'NL'):
|
26
|
+
# raise ValueError("tokenize.NL doesn't exist -- tokenize module too old")
|
27
|
+
|
28
|
+
from logilab.common.ureports import Table
|
29
|
+
|
30
|
+
from pylint.interfaces import ITokenChecker
|
31
|
+
from pylint.utils import EmptyReport
|
32
|
+
from pylint.checkers import BaseTokenChecker
|
33
|
+
from pylint.reporters import diff_string
|
34
|
+
|
35
|
+
def report_raw_stats(sect, stats, old_stats):
|
36
|
+
"""calculate percentage of code / doc / comment / empty
|
37
|
+
"""
|
38
|
+
total_lines = stats['total_lines']
|
39
|
+
if not total_lines:
|
40
|
+
raise EmptyReport()
|
41
|
+
sect.description = '%s lines have been analyzed' % total_lines
|
42
|
+
lines = ('type', 'number', '%', 'previous', 'difference')
|
43
|
+
for node_type in ('code', 'docstring', 'comment', 'empty'):
|
44
|
+
key = node_type + '_lines'
|
45
|
+
total = stats[key]
|
46
|
+
percent = float(total * 100) / total_lines
|
47
|
+
old = old_stats.get(key, None)
|
48
|
+
if old is not None:
|
49
|
+
diff_str = diff_string(old, total)
|
50
|
+
else:
|
51
|
+
old, diff_str = 'NC', 'NC'
|
52
|
+
lines += (node_type, str(total), '%.2f' % percent,
|
53
|
+
str(old), diff_str)
|
54
|
+
sect.append(Table(children=lines, cols=5, rheaders=1))
|
55
|
+
|
56
|
+
|
57
|
+
class RawMetricsChecker(BaseTokenChecker):
|
58
|
+
"""does not check anything but gives some raw metrics :
|
59
|
+
* total number of lines
|
60
|
+
* total number of code lines
|
61
|
+
* total number of docstring lines
|
62
|
+
* total number of comments lines
|
63
|
+
* total number of empty lines
|
64
|
+
"""
|
65
|
+
|
66
|
+
__implements__ = (ITokenChecker,)
|
67
|
+
|
68
|
+
# configuration section name
|
69
|
+
name = 'metrics'
|
70
|
+
# configuration options
|
71
|
+
options = ()
|
72
|
+
# messages
|
73
|
+
msgs = {}
|
74
|
+
# reports
|
75
|
+
reports = (('RP0701', 'Raw metrics', report_raw_stats),)
|
76
|
+
|
77
|
+
def __init__(self, linter):
|
78
|
+
BaseTokenChecker.__init__(self, linter)
|
79
|
+
self.stats = None
|
80
|
+
|
81
|
+
def open(self):
|
82
|
+
"""init statistics"""
|
83
|
+
self.stats = self.linter.add_stats(total_lines=0, code_lines=0,
|
84
|
+
empty_lines=0, docstring_lines=0,
|
85
|
+
comment_lines=0)
|
86
|
+
|
87
|
+
def process_tokens(self, tokens):
|
88
|
+
"""update stats"""
|
89
|
+
i = 0
|
90
|
+
tokens = list(tokens)
|
91
|
+
while i < len(tokens):
|
92
|
+
i, lines_number, line_type = get_type(tokens, i)
|
93
|
+
self.stats['total_lines'] += lines_number
|
94
|
+
self.stats[line_type] += lines_number
|
95
|
+
|
96
|
+
|
97
|
+
JUNK = (tokenize.NL, tokenize.INDENT, tokenize.NEWLINE, tokenize.ENDMARKER)
|
98
|
+
|
99
|
+
def get_type(tokens, start_index):
|
100
|
+
"""return the line type : docstring, comment, code, empty"""
|
101
|
+
i = start_index
|
102
|
+
tok_type = tokens[i][0]
|
103
|
+
start = tokens[i][2]
|
104
|
+
pos = start
|
105
|
+
line_type = None
|
106
|
+
while i < len(tokens) and tokens[i][2][0] == start[0]:
|
107
|
+
tok_type = tokens[i][0]
|
108
|
+
pos = tokens[i][3]
|
109
|
+
if line_type is None:
|
110
|
+
if tok_type == tokenize.STRING:
|
111
|
+
line_type = 'docstring_lines'
|
112
|
+
elif tok_type == tokenize.COMMENT:
|
113
|
+
line_type = 'comment_lines'
|
114
|
+
elif tok_type in JUNK:
|
115
|
+
pass
|
116
|
+
else:
|
117
|
+
line_type = 'code_lines'
|
118
|
+
i += 1
|
119
|
+
if line_type is None:
|
120
|
+
line_type = 'empty_lines'
|
121
|
+
elif i < len(tokens) and tok_type == tokenize.NEWLINE:
|
122
|
+
i += 1
|
123
|
+
return i, pos[0] - start[0] + 1, line_type
|
124
|
+
|
125
|
+
|
126
|
+
def register(linter):
|
127
|
+
""" required method to auto register this checker """
|
128
|
+
linter.register_checker(RawMetricsChecker(linter))
|
129
|
+
|
Binary file
|
@@ -0,0 +1,365 @@
|
|
1
|
+
# pylint: disable=W0622
|
2
|
+
# Copyright (c) 2004-2013 LOGILAB S.A. (Paris, FRANCE).
|
3
|
+
# http://www.logilab.fr/ -- mailto:contact@logilab.fr
|
4
|
+
#
|
5
|
+
# This program is free software; you can redistribute it and/or modify it under
|
6
|
+
# the terms of the GNU General Public License as published by the Free Software
|
7
|
+
# Foundation; either version 2 of the License, or (at your option) any later
|
8
|
+
# version.
|
9
|
+
#
|
10
|
+
# This program is distributed in the hope that it will be useful, but WITHOUT
|
11
|
+
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
12
|
+
# FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details
|
13
|
+
#
|
14
|
+
# You should have received a copy of the GNU General Public License along with
|
15
|
+
# this program; if not, write to the Free Software Foundation, Inc.,
|
16
|
+
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
17
|
+
"""a similarities / code duplication command line tool and pylint checker
|
18
|
+
"""
|
19
|
+
import sys
|
20
|
+
from itertools import izip
|
21
|
+
|
22
|
+
from logilab.common.ureports import Table
|
23
|
+
|
24
|
+
from pylint.interfaces import IRawChecker
|
25
|
+
from pylint.checkers import BaseChecker, table_lines_from_stats
|
26
|
+
|
27
|
+
|
28
|
+
class Similar(object):
|
29
|
+
"""finds copy-pasted lines of code in a project"""
|
30
|
+
|
31
|
+
def __init__(self, min_lines=4, ignore_comments=False,
|
32
|
+
ignore_docstrings=False, ignore_imports=False):
|
33
|
+
self.min_lines = min_lines
|
34
|
+
self.ignore_comments = ignore_comments
|
35
|
+
self.ignore_docstrings = ignore_docstrings
|
36
|
+
self.ignore_imports = ignore_imports
|
37
|
+
self.linesets = []
|
38
|
+
|
39
|
+
def append_stream(self, streamid, stream, encoding=None):
|
40
|
+
"""append a file to search for similarities"""
|
41
|
+
stream.seek(0) # XXX may be removed with astroid > 0.23
|
42
|
+
if encoding is None:
|
43
|
+
readlines = stream.readlines
|
44
|
+
else:
|
45
|
+
readlines = lambda: [line.decode(encoding) for line in stream]
|
46
|
+
try:
|
47
|
+
self.linesets.append(LineSet(streamid,
|
48
|
+
readlines(),
|
49
|
+
self.ignore_comments,
|
50
|
+
self.ignore_docstrings,
|
51
|
+
self.ignore_imports))
|
52
|
+
except UnicodeDecodeError:
|
53
|
+
pass
|
54
|
+
|
55
|
+
def run(self):
|
56
|
+
"""start looking for similarities and display results on stdout"""
|
57
|
+
self._display_sims(self._compute_sims())
|
58
|
+
|
59
|
+
def _compute_sims(self):
|
60
|
+
"""compute similarities in appended files"""
|
61
|
+
no_duplicates = {}
|
62
|
+
for num, lineset1, idx1, lineset2, idx2 in self._iter_sims():
|
63
|
+
duplicate = no_duplicates.setdefault(num, [])
|
64
|
+
for couples in duplicate:
|
65
|
+
if (lineset1, idx1) in couples or (lineset2, idx2) in couples:
|
66
|
+
couples.add((lineset1, idx1))
|
67
|
+
couples.add((lineset2, idx2))
|
68
|
+
break
|
69
|
+
else:
|
70
|
+
duplicate.append(set([(lineset1, idx1), (lineset2, idx2)]))
|
71
|
+
sims = []
|
72
|
+
for num, ensembles in no_duplicates.iteritems():
|
73
|
+
for couples in ensembles:
|
74
|
+
sims.append((num, couples))
|
75
|
+
sims.sort()
|
76
|
+
sims.reverse()
|
77
|
+
return sims
|
78
|
+
|
79
|
+
def _display_sims(self, sims):
|
80
|
+
"""display computed similarities on stdout"""
|
81
|
+
nb_lignes_dupliquees = 0
|
82
|
+
for num, couples in sims:
|
83
|
+
print
|
84
|
+
print num, "similar lines in", len(couples), "files"
|
85
|
+
couples = sorted(couples)
|
86
|
+
for lineset, idx in couples:
|
87
|
+
print "==%s:%s" % (lineset.name, idx)
|
88
|
+
# pylint: disable=W0631
|
89
|
+
for line in lineset._real_lines[idx:idx+num]:
|
90
|
+
print " ", line.rstrip()
|
91
|
+
nb_lignes_dupliquees += num * (len(couples)-1)
|
92
|
+
nb_total_lignes = sum([len(lineset) for lineset in self.linesets])
|
93
|
+
print "TOTAL lines=%s duplicates=%s percent=%.2f" \
|
94
|
+
% (nb_total_lignes, nb_lignes_dupliquees,
|
95
|
+
nb_lignes_dupliquees*100. / nb_total_lignes)
|
96
|
+
|
97
|
+
def _find_common(self, lineset1, lineset2):
|
98
|
+
"""find similarities in the two given linesets"""
|
99
|
+
lines1 = lineset1.enumerate_stripped
|
100
|
+
lines2 = lineset2.enumerate_stripped
|
101
|
+
find = lineset2.find
|
102
|
+
index1 = 0
|
103
|
+
min_lines = self.min_lines
|
104
|
+
while index1 < len(lineset1):
|
105
|
+
skip = 1
|
106
|
+
num = 0
|
107
|
+
for index2 in find(lineset1[index1]):
|
108
|
+
non_blank = 0
|
109
|
+
for num, ((_, line1), (_, line2)) in enumerate(
|
110
|
+
izip(lines1(index1), lines2(index2))):
|
111
|
+
if line1 != line2:
|
112
|
+
if non_blank > min_lines:
|
113
|
+
yield num, lineset1, index1, lineset2, index2
|
114
|
+
skip = max(skip, num)
|
115
|
+
break
|
116
|
+
if line1:
|
117
|
+
non_blank += 1
|
118
|
+
else:
|
119
|
+
# we may have reach the end
|
120
|
+
num += 1
|
121
|
+
if non_blank > min_lines:
|
122
|
+
yield num, lineset1, index1, lineset2, index2
|
123
|
+
skip = max(skip, num)
|
124
|
+
index1 += skip
|
125
|
+
|
126
|
+
def _iter_sims(self):
|
127
|
+
"""iterate on similarities among all files, by making a cartesian
|
128
|
+
product
|
129
|
+
"""
|
130
|
+
for idx, lineset in enumerate(self.linesets[:-1]):
|
131
|
+
for lineset2 in self.linesets[idx+1:]:
|
132
|
+
for sim in self._find_common(lineset, lineset2):
|
133
|
+
yield sim
|
134
|
+
|
135
|
+
def stripped_lines(lines, ignore_comments, ignore_docstrings, ignore_imports):
|
136
|
+
"""return lines with leading/trailing whitespace and any ignored code
|
137
|
+
features removed
|
138
|
+
"""
|
139
|
+
|
140
|
+
strippedlines = []
|
141
|
+
docstring = None
|
142
|
+
for line in lines:
|
143
|
+
line = line.strip()
|
144
|
+
if ignore_docstrings:
|
145
|
+
if not docstring and \
|
146
|
+
(line.startswith('"""') or line.startswith("'''")):
|
147
|
+
docstring = line[:3]
|
148
|
+
line = line[3:]
|
149
|
+
if docstring:
|
150
|
+
if line.endswith(docstring):
|
151
|
+
docstring = None
|
152
|
+
line = ''
|
153
|
+
if ignore_imports:
|
154
|
+
if line.startswith("import ") or line.startswith("from "):
|
155
|
+
line = ''
|
156
|
+
if ignore_comments:
|
157
|
+
# XXX should use regex in checkers/format to avoid cutting
|
158
|
+
# at a "#" in a string
|
159
|
+
line = line.split('#', 1)[0].strip()
|
160
|
+
strippedlines.append(line)
|
161
|
+
return strippedlines
|
162
|
+
|
163
|
+
|
164
|
+
class LineSet(object):
|
165
|
+
"""Holds and indexes all the lines of a single source file"""
|
166
|
+
def __init__(self, name, lines, ignore_comments=False,
|
167
|
+
ignore_docstrings=False, ignore_imports=False):
|
168
|
+
self.name = name
|
169
|
+
self._real_lines = lines
|
170
|
+
self._stripped_lines = stripped_lines(lines, ignore_comments,
|
171
|
+
ignore_docstrings,
|
172
|
+
ignore_imports)
|
173
|
+
self._index = self._mk_index()
|
174
|
+
|
175
|
+
def __str__(self):
|
176
|
+
return '<Lineset for %s>' % self.name
|
177
|
+
|
178
|
+
def __len__(self):
|
179
|
+
return len(self._real_lines)
|
180
|
+
|
181
|
+
def __getitem__(self, index):
|
182
|
+
return self._stripped_lines[index]
|
183
|
+
|
184
|
+
def __lt__(self, other):
|
185
|
+
return self.name < other.name
|
186
|
+
|
187
|
+
def __hash__(self):
|
188
|
+
return id(self)
|
189
|
+
|
190
|
+
def enumerate_stripped(self, start_at=0):
|
191
|
+
"""return an iterator on stripped lines, starting from a given index
|
192
|
+
if specified, else 0
|
193
|
+
"""
|
194
|
+
idx = start_at
|
195
|
+
if start_at:
|
196
|
+
lines = self._stripped_lines[start_at:]
|
197
|
+
else:
|
198
|
+
lines = self._stripped_lines
|
199
|
+
for line in lines:
|
200
|
+
#if line:
|
201
|
+
yield idx, line
|
202
|
+
idx += 1
|
203
|
+
|
204
|
+
def find(self, stripped_line):
|
205
|
+
"""return positions of the given stripped line in this set"""
|
206
|
+
return self._index.get(stripped_line, ())
|
207
|
+
|
208
|
+
def _mk_index(self):
|
209
|
+
"""create the index for this set"""
|
210
|
+
index = {}
|
211
|
+
for line_no, line in enumerate(self._stripped_lines):
|
212
|
+
if line:
|
213
|
+
index.setdefault(line, []).append(line_no)
|
214
|
+
return index
|
215
|
+
|
216
|
+
|
217
|
+
MSGS = {'R0801': ('Similar lines in %s files\n%s',
|
218
|
+
'duplicate-code',
|
219
|
+
'Indicates that a set of similar lines has been detected \
|
220
|
+
among multiple file. This usually means that the code should \
|
221
|
+
be refactored to avoid this duplication.')}
|
222
|
+
|
223
|
+
def report_similarities(sect, stats, old_stats):
|
224
|
+
"""make a layout with some stats about duplication"""
|
225
|
+
lines = ['', 'now', 'previous', 'difference']
|
226
|
+
lines += table_lines_from_stats(stats, old_stats,
|
227
|
+
('nb_duplicated_lines',
|
228
|
+
'percent_duplicated_lines'))
|
229
|
+
sect.append(Table(children=lines, cols=4, rheaders=1, cheaders=1))
|
230
|
+
|
231
|
+
|
232
|
+
# wrapper to get a pylint checker from the similar class
|
233
|
+
class SimilarChecker(BaseChecker, Similar):
|
234
|
+
"""checks for similarities and duplicated code. This computation may be
|
235
|
+
memory / CPU intensive, so you should disable it if you experiment some
|
236
|
+
problems.
|
237
|
+
"""
|
238
|
+
|
239
|
+
__implements__ = (IRawChecker,)
|
240
|
+
# configuration section name
|
241
|
+
name = 'similarities'
|
242
|
+
# messages
|
243
|
+
msgs = MSGS
|
244
|
+
# configuration options
|
245
|
+
# for available dict keys/values see the optik parser 'add_option' method
|
246
|
+
options = (('min-similarity-lines',
|
247
|
+
{'default' : 4, 'type' : "int", 'metavar' : '<int>',
|
248
|
+
'help' : 'Minimum lines number of a similarity.'}),
|
249
|
+
('ignore-comments',
|
250
|
+
{'default' : True, 'type' : 'yn', 'metavar' : '<y or n>',
|
251
|
+
'help': 'Ignore comments when computing similarities.'}
|
252
|
+
),
|
253
|
+
('ignore-docstrings',
|
254
|
+
{'default' : True, 'type' : 'yn', 'metavar' : '<y or n>',
|
255
|
+
'help': 'Ignore docstrings when computing similarities.'}
|
256
|
+
),
|
257
|
+
('ignore-imports',
|
258
|
+
{'default' : False, 'type' : 'yn', 'metavar' : '<y or n>',
|
259
|
+
'help': 'Ignore imports when computing similarities.'}
|
260
|
+
),
|
261
|
+
)
|
262
|
+
# reports
|
263
|
+
reports = (('RP0801', 'Duplication', report_similarities),)
|
264
|
+
|
265
|
+
def __init__(self, linter=None):
|
266
|
+
BaseChecker.__init__(self, linter)
|
267
|
+
Similar.__init__(self, min_lines=4,
|
268
|
+
ignore_comments=True, ignore_docstrings=True)
|
269
|
+
self.stats = None
|
270
|
+
|
271
|
+
def set_option(self, optname, value, action=None, optdict=None):
|
272
|
+
"""method called to set an option (registered in the options list)
|
273
|
+
|
274
|
+
overridden to report options setting to Similar
|
275
|
+
"""
|
276
|
+
BaseChecker.set_option(self, optname, value, action, optdict)
|
277
|
+
if optname == 'min-similarity-lines':
|
278
|
+
self.min_lines = self.config.min_similarity_lines
|
279
|
+
elif optname == 'ignore-comments':
|
280
|
+
self.ignore_comments = self.config.ignore_comments
|
281
|
+
elif optname == 'ignore-docstrings':
|
282
|
+
self.ignore_docstrings = self.config.ignore_docstrings
|
283
|
+
elif optname == 'ignore-imports':
|
284
|
+
self.ignore_imports = self.config.ignore_imports
|
285
|
+
|
286
|
+
def open(self):
|
287
|
+
"""init the checkers: reset linesets and statistics information"""
|
288
|
+
self.linesets = []
|
289
|
+
self.stats = self.linter.add_stats(nb_duplicated_lines=0,
|
290
|
+
percent_duplicated_lines=0)
|
291
|
+
|
292
|
+
def process_module(self, node):
|
293
|
+
"""process a module
|
294
|
+
|
295
|
+
the module's content is accessible via the stream object
|
296
|
+
|
297
|
+
stream must implement the readlines method
|
298
|
+
"""
|
299
|
+
self.append_stream(self.linter.current_name, node.file_stream, node.file_encoding)
|
300
|
+
|
301
|
+
def close(self):
|
302
|
+
"""compute and display similarities on closing (i.e. end of parsing)"""
|
303
|
+
total = sum([len(lineset) for lineset in self.linesets])
|
304
|
+
duplicated = 0
|
305
|
+
stats = self.stats
|
306
|
+
for num, couples in self._compute_sims():
|
307
|
+
msg = []
|
308
|
+
for lineset, idx in couples:
|
309
|
+
msg.append("==%s:%s" % (lineset.name, idx))
|
310
|
+
msg.sort()
|
311
|
+
# pylint: disable=W0631
|
312
|
+
for line in lineset._real_lines[idx:idx+num]:
|
313
|
+
msg.append(line.rstrip())
|
314
|
+
self.add_message('R0801', args=(len(couples), '\n'.join(msg)))
|
315
|
+
duplicated += num * (len(couples) - 1)
|
316
|
+
stats['nb_duplicated_lines'] = duplicated
|
317
|
+
stats['percent_duplicated_lines'] = total and duplicated * 100. / total
|
318
|
+
|
319
|
+
|
320
|
+
def register(linter):
|
321
|
+
"""required method to auto register this checker """
|
322
|
+
linter.register_checker(SimilarChecker(linter))
|
323
|
+
|
324
|
+
def usage(status=0):
|
325
|
+
"""display command line usage information"""
|
326
|
+
print "finds copy pasted blocks in a set of files"
|
327
|
+
print
|
328
|
+
print 'Usage: symilar [-d|--duplicates min_duplicated_lines] \
|
329
|
+
[-i|--ignore-comments] [--ignore-docstrings] [--ignore-imports] file1...'
|
330
|
+
sys.exit(status)
|
331
|
+
|
332
|
+
def Run(argv=None):
|
333
|
+
"""standalone command line access point"""
|
334
|
+
if argv is None:
|
335
|
+
argv = sys.argv[1:]
|
336
|
+
from getopt import getopt
|
337
|
+
s_opts = 'hdi'
|
338
|
+
l_opts = ('help', 'duplicates=', 'ignore-comments', 'ignore-imports',
|
339
|
+
'ignore-docstrings')
|
340
|
+
min_lines = 4
|
341
|
+
ignore_comments = False
|
342
|
+
ignore_docstrings = False
|
343
|
+
ignore_imports = False
|
344
|
+
opts, args = getopt(argv, s_opts, l_opts)
|
345
|
+
for opt, val in opts:
|
346
|
+
if opt in ('-d', '--duplicates'):
|
347
|
+
min_lines = int(val)
|
348
|
+
elif opt in ('-h', '--help'):
|
349
|
+
usage()
|
350
|
+
elif opt in ('-i', '--ignore-comments'):
|
351
|
+
ignore_comments = True
|
352
|
+
elif opt in ('--ignore-docstrings',):
|
353
|
+
ignore_docstrings = True
|
354
|
+
elif opt in ('--ignore-imports',):
|
355
|
+
ignore_imports = True
|
356
|
+
if not args:
|
357
|
+
usage(1)
|
358
|
+
sim = Similar(min_lines, ignore_comments, ignore_docstrings, ignore_imports)
|
359
|
+
for filename in args:
|
360
|
+
sim.append_stream(filename, open(filename))
|
361
|
+
sim.run()
|
362
|
+
sys.exit(0)
|
363
|
+
|
364
|
+
if __name__ == '__main__':
|
365
|
+
Run()
|