mirror of
				https://github.com/KevinMidboe/linguist.git
				synced 2025-10-29 17:50:22 +00:00 
			
		
		
		
	Load Git Attributes for Linguist-specific overrides
This commit is contained in:
		
				
					committed by
					
						
						The rugged tests are fragile
					
				
			
			
				
	
			
			
			
						parent
						
							16c1aa2845
						
					
				
				
					commit
					3d39e842ec
				
			@@ -1,8 +1,13 @@
 | 
			
		||||
require 'linguist/blob_helper'
 | 
			
		||||
require 'linguist/language'
 | 
			
		||||
require 'rugged'
 | 
			
		||||
 | 
			
		||||
module Linguist
 | 
			
		||||
  class LazyBlob
 | 
			
		||||
    GIT_ATTR = ['linguist-ignore', 'linguist-lang']
 | 
			
		||||
    GIT_ATTR_OPTS = { :priority => [:index], :skip_system => true }
 | 
			
		||||
    GIT_ATTR_FLAGS = Rugged::Repository::Attributes.parse_opts(GIT_ATTR_OPTS)
 | 
			
		||||
 | 
			
		||||
    include BlobHelper
 | 
			
		||||
 | 
			
		||||
    MAX_SIZE = 128 * 1024
 | 
			
		||||
@@ -19,6 +24,25 @@ module Linguist
 | 
			
		||||
      @mode = mode
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    def git_attributes
 | 
			
		||||
      @git_attributes ||= repository.fetch_attributes(
 | 
			
		||||
        name, GIT_ATTR, GIT_ATTR_FLAGS)
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    def ignored?
 | 
			
		||||
      !!git_attributes['linguist-ignore']
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    def overriden_language
 | 
			
		||||
      if lang = git_attributes['linguist-lang']
 | 
			
		||||
        Language.find_by_name(lang)
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    def language
 | 
			
		||||
      @language ||= (overriden_language || Language.detect(self))
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    def data
 | 
			
		||||
      load_blob!
 | 
			
		||||
      @data
 | 
			
		||||
 
 | 
			
		||||
@@ -123,6 +123,10 @@ module Linguist
 | 
			
		||||
 | 
			
		||||
      diff = Rugged::Tree.diff(repository, old_tree, new_tree)
 | 
			
		||||
 | 
			
		||||
      attr_index = Rugged::Index.new
 | 
			
		||||
      attr_index.read_tree(new_tree)
 | 
			
		||||
      repository.index = attr_index
 | 
			
		||||
 | 
			
		||||
      diff.each_delta do |delta|
 | 
			
		||||
        old = delta.old_file[:path]
 | 
			
		||||
        new = delta.new_file[:path]
 | 
			
		||||
@@ -138,7 +142,7 @@ module Linguist
 | 
			
		||||
          blob = Linguist::LazyBlob.new(repository, delta.new_file[:oid], new, mode.to_s(8))
 | 
			
		||||
 | 
			
		||||
          # Skip vendored or generated blobs
 | 
			
		||||
          next if blob.vendored? || blob.generated? || blob.language.nil?
 | 
			
		||||
          next if blob.ignored? || blob.vendored? || blob.generated? || blob.language.nil?
 | 
			
		||||
 | 
			
		||||
          # Only include programming languages and acceptable markup languages
 | 
			
		||||
          if blob.language.type == :programming || Language.detectable_markup.include?(blob.language.name)
 | 
			
		||||
 
 | 
			
		||||
@@ -47,4 +47,18 @@ class TestRepository < Test::Unit::TestCase
 | 
			
		||||
 | 
			
		||||
    assert_equal linguist_repo.cache, new_repo.cache
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def test_git_attributes
 | 
			
		||||
    attr_commit = '525304738ebdb7ab3b7d2bf9a7514cc428faa273'
 | 
			
		||||
    repo = linguist_repo(attr_commit)
 | 
			
		||||
 | 
			
		||||
    assert repo.breakdown_by_file.has_key?("Java")
 | 
			
		||||
    assert repo.breakdown_by_file["Java"].include?("lib/linguist.rb")
 | 
			
		||||
 | 
			
		||||
    assert repo.breakdown_by_file.has_key?("Ruby")
 | 
			
		||||
    assert !repo.breakdown_by_file["Ruby"].empty?
 | 
			
		||||
    repo.breakdown_by_file["Ruby"].each do |file|
 | 
			
		||||
      assert !file.start_with?("test/")
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
end
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user