diff options
| author | Paco Guzman <pacoguzmanp@gmail.com> | 2016-07-27 19:00:34 +0200 | 
|---|---|---|
| committer | Paco Guzman <pacoguzmanp@gmail.com> | 2016-08-03 07:00:20 +0200 | 
| commit | c86c1905b5574cac234315598d8d715fcaee3ea7 (patch) | |
| tree | 31ba7ab51c04b07ea70d15db88f2370f9ca6359e /lib | |
| parent | 1d0c7b74920a94e488e6a2c090abb3e525438053 (diff) | |
| download | gitlab-ce-c86c1905b5574cac234315598d8d715fcaee3ea7.tar.gz | |
switch from diff_file_collection to diffs20034-safe-diffs
So we have raw_diffs too
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/api/commits.rb | 4 | ||||
| -rw-r--r-- | lib/api/entities.rb | 2 | ||||
| -rw-r--r-- | lib/gitlab/diff/file_collection.rb | 9 | ||||
| -rw-r--r-- | lib/gitlab/diff/file_collection/base.rb | 17 | ||||
| -rw-r--r-- | lib/gitlab/diff/file_collection/commit.rb | 5 | ||||
| -rw-r--r-- | lib/gitlab/diff/file_collection/compare.rb | 5 | ||||
| -rw-r--r-- | lib/gitlab/diff/file_collection/merge_request.rb | 23 | ||||
| -rw-r--r-- | lib/gitlab/email/message/repository_push.rb | 3 | 
8 files changed, 24 insertions, 44 deletions
| diff --git a/lib/api/commits.rb b/lib/api/commits.rb index 4a11c8e3620..b4eaf1813d4 100644 --- a/lib/api/commits.rb +++ b/lib/api/commits.rb @@ -54,7 +54,7 @@ module API          sha = params[:sha]          commit = user_project.commit(sha)          not_found! "Commit" unless commit -        commit.diffs.to_a +        commit.raw_diffs.to_a        end        # Get a commit's comments @@ -96,7 +96,7 @@ module API          }          if params[:path] && params[:line] && params[:line_type] -          commit.diffs(all_diffs: true).each do |diff| +          commit.raw_diffs(all_diffs: true).each do |diff|              next unless diff.new_path == params[:path]              lines = Gitlab::Diff::Parser.new.parse(diff.diff.each_line) diff --git a/lib/api/entities.rb b/lib/api/entities.rb index 3e21b7a0b8a..e5b00dc45a5 100644 --- a/lib/api/entities.rb +++ b/lib/api/entities.rb @@ -224,7 +224,7 @@ module API      class MergeRequestChanges < MergeRequest        expose :diffs, as: :changes, using: Entities::RepoDiff do |compare, _| -        compare.diffs(all_diffs: true).to_a +        compare.raw_diffs(all_diffs: true).to_a        end      end diff --git a/lib/gitlab/diff/file_collection.rb b/lib/gitlab/diff/file_collection.rb deleted file mode 100644 index ce6717c7205..00000000000 --- a/lib/gitlab/diff/file_collection.rb +++ /dev/null @@ -1,9 +0,0 @@ -module Gitlab -  module Diff -    module FileCollection -      def self.default_options -        ::Commit.max_diff_options.merge(ignore_whitespace_change: false, no_collapse: false) -      end -    end -  end -end diff --git a/lib/gitlab/diff/file_collection/base.rb b/lib/gitlab/diff/file_collection/base.rb index a0c88265c45..2b9fc65b985 100644 --- a/lib/gitlab/diff/file_collection/base.rb +++ b/lib/gitlab/diff/file_collection/base.rb @@ -1,28 +1,33 @@  module Gitlab    module Diff      module FileCollection -        class Base          attr_reader :project, :diff_options, :diff_view, :diff_refs          delegate :count, :size, :real_size, to: :diff_files -        def initialize(diffs, project:, diff_options: nil, diff_refs: nil) -          @diffs        = diffs +        def self.default_options +          ::Commit.max_diff_options.merge(ignore_whitespace_change: false, no_collapse: false) +        end + +        def initialize(diffable, project:, diff_options: nil, diff_refs: nil) +          diff_options = self.class.default_options.merge(diff_options || {}) + +          @diffable     = diffable +          @diffs        = diffable.raw_diffs(diff_options)            @project      = project            @diff_options = diff_options            @diff_refs    = diff_refs          end          def diff_files -          @diffs.decorate! { |diff| decorate_diff!(diff) } +          @diff_files ||= @diffs.decorate! { |diff| decorate_diff!(diff) }          end          private          def decorate_diff!(diff) -          return diff if diff.is_a?(Gitlab::Diff::File) -          Gitlab::Diff::File.new(diff, diff_refs: @diff_refs, repository: @project.repository) +          Gitlab::Diff::File.new(diff, repository: project.repository, diff_refs: diff_refs)          end        end      end diff --git a/lib/gitlab/diff/file_collection/commit.rb b/lib/gitlab/diff/file_collection/commit.rb index 19def300b74..4dc297ec036 100644 --- a/lib/gitlab/diff/file_collection/commit.rb +++ b/lib/gitlab/diff/file_collection/commit.rb @@ -3,10 +3,7 @@ module Gitlab      module FileCollection        class Commit < Base          def initialize(commit, diff_options:) -          # Not merge just set defaults -          diff_options = diff_options || Gitlab::Diff::FileCollection.default_options - -          super(commit.diffs(diff_options), +          super(commit,              project: commit.project,              diff_options: diff_options,              diff_refs: commit.diff_refs) diff --git a/lib/gitlab/diff/file_collection/compare.rb b/lib/gitlab/diff/file_collection/compare.rb index aba5a28b51f..20d8f891cc3 100644 --- a/lib/gitlab/diff/file_collection/compare.rb +++ b/lib/gitlab/diff/file_collection/compare.rb @@ -3,10 +3,7 @@ module Gitlab      module FileCollection        class Compare < Base          def initialize(compare, project:, diff_options:, diff_refs: nil) -          # Not merge just set defaults -          diff_options = diff_options || Gitlab::Diff::FileCollection.default_options - -          super(compare.diffs(diff_options), +          super(compare,              project:      project,              diff_options: diff_options,              diff_refs:    diff_refs) diff --git a/lib/gitlab/diff/file_collection/merge_request.rb b/lib/gitlab/diff/file_collection/merge_request.rb index 9fde0bba183..4f946908e2f 100644 --- a/lib/gitlab/diff/file_collection/merge_request.rb +++ b/lib/gitlab/diff/file_collection/merge_request.rb @@ -4,10 +4,8 @@ module Gitlab        class MergeRequest < Base          def initialize(merge_request, diff_options:)            @merge_request = merge_request -          # Not merge just set defaults -          diff_options = diff_options || Gitlab::Diff::FileCollection.default_options -          super(merge_request.diffs(diff_options), +          super(merge_request,              project: merge_request.project,              diff_options: diff_options,              diff_refs: merge_request.diff_refs) @@ -19,18 +17,11 @@ module Gitlab          private -        # Extracted method to highlight in the same iteration to the diff_collection. Iteration in the DiffCollections -        # seems particularly slow on big diffs (event when already populated). +        # Extracted method to highlight in the same iteration to the diff_collection.          def decorate_diff!(diff) -          highlight! super -        end - -        def highlight!(diff_file) -          if cacheable? -            cache_highlight!(diff_file) -          else -            diff_file # Don't need to eager load highlighted diff lines -          end +          diff_file = super +          cache_highlight!(diff_file) if cacheable? +          diff_file          end          def highlight_diff_file_from_cache!(diff_file, cache_diff_lines) @@ -55,15 +46,13 @@ module Gitlab            else              highlight_cache[file_path] = diff_file.highlighted_diff_lines.map(&:to_hash)            end - -          diff_file          end          def highlight_cache            return @highlight_cache if defined?(@highlight_cache)            @highlight_cache = Rails.cache.read(cache_key) || {} -          @highlight_cache_was_empty = highlight_cache.empty? +          @highlight_cache_was_empty = @highlight_cache.empty?            @highlight_cache          end diff --git a/lib/gitlab/email/message/repository_push.rb b/lib/gitlab/email/message/repository_push.rb index 16491ede71b..62d29387d60 100644 --- a/lib/gitlab/email/message/repository_push.rb +++ b/lib/gitlab/email/message/repository_push.rb @@ -41,7 +41,8 @@ module Gitlab          def diffs            return unless compare -          @diffs ||= compare.diff_file_collection(diff_options: { max_files: 30 }).diff_files +          # This diff is more moderated in number of files and lines +          @diffs ||= compare.diffs(diff_options: { max_files: 30, max_lines: 5000, no_collapse: true }).diff_files          end          def diffs_count | 
