mirror of
https://github.com/KevinMidboe/linguist.git
synced 2025-10-29 17:50:22 +00:00
Revert "Load Git Attributes for Linguist-specific overrides"
This commit is contained in:
@@ -1,7 +1,6 @@
|
|||||||
before_install:
|
before_install:
|
||||||
- git fetch origin master:master
|
- git fetch origin master:master
|
||||||
- git fetch origin v2.0.0:v2.0.0
|
- git fetch origin v2.0.0:v2.0.0
|
||||||
- git fetch origin test/attributes:test/attributes
|
|
||||||
- sudo apt-get install libicu-dev -y
|
- sudo apt-get install libicu-dev -y
|
||||||
rvm:
|
rvm:
|
||||||
- 1.9.3
|
- 1.9.3
|
||||||
|
|||||||
1
Gemfile
1
Gemfile
@@ -1,3 +1,2 @@
|
|||||||
source 'https://rubygems.org'
|
source 'https://rubygems.org'
|
||||||
gemspec
|
gemspec
|
||||||
gem 'rugged', '0.21.1b1'
|
|
||||||
|
|||||||
@@ -17,6 +17,7 @@ Gem::Specification.new do |s|
|
|||||||
s.add_dependency 'escape_utils', '~> 1.0.1'
|
s.add_dependency 'escape_utils', '~> 1.0.1'
|
||||||
s.add_dependency 'mime-types', '~> 1.19'
|
s.add_dependency 'mime-types', '~> 1.19'
|
||||||
s.add_dependency 'pygments.rb', '~> 0.6.0'
|
s.add_dependency 'pygments.rb', '~> 0.6.0'
|
||||||
|
s.add_dependency 'rugged', '~> 0.21.0'
|
||||||
|
|
||||||
s.add_development_dependency 'json'
|
s.add_development_dependency 'json'
|
||||||
s.add_development_dependency 'mocha'
|
s.add_development_dependency 'mocha'
|
||||||
|
|||||||
@@ -1,13 +1,8 @@
|
|||||||
require 'linguist/blob_helper'
|
require 'linguist/blob_helper'
|
||||||
require 'linguist/language'
|
|
||||||
require 'rugged'
|
require 'rugged'
|
||||||
|
|
||||||
module Linguist
|
module Linguist
|
||||||
class LazyBlob
|
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
|
include BlobHelper
|
||||||
|
|
||||||
MAX_SIZE = 128 * 1024
|
MAX_SIZE = 128 * 1024
|
||||||
@@ -24,25 +19,6 @@ module Linguist
|
|||||||
@mode = mode
|
@mode = mode
|
||||||
end
|
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
|
def data
|
||||||
load_blob!
|
load_blob!
|
||||||
@data
|
@data
|
||||||
|
|||||||
@@ -123,10 +123,6 @@ module Linguist
|
|||||||
|
|
||||||
diff = Rugged::Tree.diff(repository, old_tree, new_tree)
|
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|
|
diff.each_delta do |delta|
|
||||||
old = delta.old_file[:path]
|
old = delta.old_file[:path]
|
||||||
new = delta.new_file[:path]
|
new = delta.new_file[:path]
|
||||||
@@ -142,7 +138,7 @@ module Linguist
|
|||||||
blob = Linguist::LazyBlob.new(repository, delta.new_file[:oid], new, mode.to_s(8))
|
blob = Linguist::LazyBlob.new(repository, delta.new_file[:oid], new, mode.to_s(8))
|
||||||
|
|
||||||
# Skip vendored or generated blobs
|
# Skip vendored or generated blobs
|
||||||
next if blob.ignored? || blob.vendored? || blob.generated? || blob.language.nil?
|
next if blob.vendored? || blob.generated? || blob.language.nil?
|
||||||
|
|
||||||
# Only include programming languages and acceptable markup languages
|
# Only include programming languages and acceptable markup languages
|
||||||
if blob.language.type == :programming || Language.detectable_markup.include?(blob.language.name)
|
if blob.language.type == :programming || Language.detectable_markup.include?(blob.language.name)
|
||||||
|
|||||||
@@ -47,18 +47,4 @@ class TestRepository < Test::Unit::TestCase
|
|||||||
|
|
||||||
assert_equal linguist_repo.cache, new_repo.cache
|
assert_equal linguist_repo.cache, new_repo.cache
|
||||||
end
|
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
|
end
|
||||||
|
|||||||
Reference in New Issue
Block a user