Class: Quality::LinguistSourceFileGlobber
- Inherits:
-
Object
- Object
- Quality::LinguistSourceFileGlobber
- Defined in:
- lib/quality/linguist_source_file_globber.rb
Overview
Uses the Linguist gem to find and classify source files.
Note: Requires files to be commited within a git repo.
Instance Attribute Summary collapse
Instance Method Summary collapse
- #all_files ⇒ Object
-
#initialize(repo: Rugged::Repository.new('.'), commit: repo.head, project: Linguist::Repository.new(repo, commit.target_id), file_blob: Linguist::FileBlob, pwd: Dir.pwd) ⇒ LinguistSourceFileGlobber
constructor
A new instance of LinguistSourceFileGlobber.
- #js_files ⇒ Object
- #language_files(language) ⇒ Object
- #python_files ⇒ Object
- #real_files_matching ⇒ Object
- #ruby_files ⇒ Object
- #source_and_doc_files ⇒ Object
- #source_files ⇒ Object
- #submodule_or_symlink?(file) ⇒ Boolean
Constructor Details
#initialize(repo: Rugged::Repository.new('.'), commit: repo.head, project: Linguist::Repository.new(repo, commit.target_id), file_blob: Linguist::FileBlob, pwd: Dir.pwd) ⇒ LinguistSourceFileGlobber
Returns a new instance of LinguistSourceFileGlobber.
10 11 12 13 14 15 16 17 18 19 20 21 22 |
# File 'lib/quality/linguist_source_file_globber.rb', line 10 def initialize(repo: Rugged::Repository.new('.'), commit: repo.head, project: Linguist::Repository.new(repo, commit.target_id), file_blob: Linguist::FileBlob, pwd: Dir.pwd) @repo = repo @commit = commit @project = project @breakdown_by_file = @project.breakdown_by_file @file_blob = file_blob @exclude_files = nil @pwd = pwd end |
Instance Attribute Details
#exclude_files ⇒ Object
67 68 69 |
# File 'lib/quality/linguist_source_file_globber.rb', line 67 def exclude_files @exclude_files || [] end |
Instance Method Details
#all_files ⇒ Object
35 36 37 38 39 40 41 42 43 44 45 46 |
# File 'lib/quality/linguist_source_file_globber.rb', line 35 def all_files @source_files ||= begin files = [] tree = @commit.target.tree tree.walk(:preorder) do |root, file| unless file[:type] != :blob || submodule_or_symlink?(file) files << "#{root}#{file[:name]}" end end files end end |
#js_files ⇒ Object
63 64 65 |
# File 'lib/quality/linguist_source_file_globber.rb', line 63 def js_files language_files('JavaScript') end |
#language_files(language) ⇒ Object
48 49 50 |
# File 'lib/quality/linguist_source_file_globber.rb', line 48 def language_files(language) (@breakdown_by_file[language] || []) - exclude_files end |
#python_files ⇒ Object
59 60 61 |
# File 'lib/quality/linguist_source_file_globber.rb', line 59 def python_files language_files('Python') end |
#real_files_matching ⇒ Object
71 72 73 74 75 76 77 78 79 80 |
# File 'lib/quality/linguist_source_file_globber.rb', line 71 def real_files_matching all_files.select do |filename| blob = @file_blob.new(filename, @pwd) if blob.generated? || blob.vendored? false else yield blob, filename end end end |
#ruby_files ⇒ Object
52 53 54 55 56 57 |
# File 'lib/quality/linguist_source_file_globber.rb', line 52 def ruby_files # Linguist treats Gemfile.lock as Ruby code. # # https://github.com/github/linguist/issues/1740 language_files('Ruby') - ['Gemfile.lock'] end |
#source_and_doc_files ⇒ Object
90 91 92 93 94 95 96 97 98 99 100 101 |
# File 'lib/quality/linguist_source_file_globber.rb', line 90 def source_and_doc_files @source_and_doc_files ||= begin real_files_matching do |blob, _filename| if blob.documentation? || !blob.language.nil? true else # puts "Excluding #{filename} from source_and_doc_files" false end end end end |
#source_files ⇒ Object
82 83 84 85 86 87 88 |
# File 'lib/quality/linguist_source_file_globber.rb', line 82 def source_files @source_files ||= begin real_files_matching do |blob| !blob.language.nil? end end end |
#submodule_or_symlink?(file) ⇒ Boolean
26 27 28 29 30 31 32 33 |
# File 'lib/quality/linguist_source_file_globber.rb', line 26 def submodule_or_symlink?(file) # Skip submodules and symlinks mode = file[:filemode] mode_format = (mode & 0o0170000) mode_format == 0o0120000 || mode_format == 0o040000 || mode_format == 0o0160000 end |