diff options
| author | Paco Guzman <pacoguzmanp@gmail.com> | 2016-07-27 13:09:52 +0200 | 
|---|---|---|
| committer | Paco Guzman <pacoguzmanp@gmail.com> | 2016-08-03 07:00:20 +0200 | 
| commit | 1d0c7b74920a94e488e6a2c090abb3e525438053 (patch) | |
| tree | 746321bd5aa1d580f8df0337389fb92bb64ca1eb /lib | |
| parent | 8f359ea9170b984ad43d126e17628c31ac3a1f14 (diff) | |
| download | gitlab-ce-1d0c7b74920a94e488e6a2c090abb3e525438053.tar.gz | |
Introduce Compare model in the codebase.
This object will manage Gitlab::Git::Compare instances
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/gitlab/diff/file_collection/base.rb | 2 | ||||
| -rw-r--r-- | lib/gitlab/diff/file_collection/commit.rb | 3 | ||||
| -rw-r--r-- | lib/gitlab/diff/file_collection/compare.rb | 3 | ||||
| -rw-r--r-- | lib/gitlab/diff/file_collection/merge_request.rb | 10 | ||||
| -rw-r--r-- | lib/gitlab/email/message/repository_push.rb | 18 | 
5 files changed, 19 insertions, 17 deletions
| diff --git a/lib/gitlab/diff/file_collection/base.rb b/lib/gitlab/diff/file_collection/base.rb index 20562773c14..a0c88265c45 100644 --- a/lib/gitlab/diff/file_collection/base.rb +++ b/lib/gitlab/diff/file_collection/base.rb @@ -7,7 +7,7 @@ module Gitlab          delegate :count, :size, :real_size, to: :diff_files -        def initialize(diffs, project:, diff_options:, diff_refs: nil) +        def initialize(diffs, project:, diff_options: nil, diff_refs: nil)            @diffs        = diffs            @project      = project            @diff_options = diff_options diff --git a/lib/gitlab/diff/file_collection/commit.rb b/lib/gitlab/diff/file_collection/commit.rb index 2a46109ad99..19def300b74 100644 --- a/lib/gitlab/diff/file_collection/commit.rb +++ b/lib/gitlab/diff/file_collection/commit.rb @@ -3,6 +3,9 @@ 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),              project: commit.project,              diff_options: diff_options, diff --git a/lib/gitlab/diff/file_collection/compare.rb b/lib/gitlab/diff/file_collection/compare.rb index 1bcda145f15..aba5a28b51f 100644 --- a/lib/gitlab/diff/file_collection/compare.rb +++ b/lib/gitlab/diff/file_collection/compare.rb @@ -3,6 +3,9 @@ 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),              project:      project,              diff_options: diff_options, diff --git a/lib/gitlab/diff/file_collection/merge_request.rb b/lib/gitlab/diff/file_collection/merge_request.rb index 7c40622d594..9fde0bba183 100644 --- a/lib/gitlab/diff/file_collection/merge_request.rb +++ b/lib/gitlab/diff/file_collection/merge_request.rb @@ -4,6 +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),              project: merge_request.project, @@ -27,15 +29,10 @@ module Gitlab            if cacheable?              cache_highlight!(diff_file)            else -            highlight_diff_file!(diff_file) +            diff_file # Don't need to eager load highlighted diff lines            end          end -        def highlight_diff_file!(diff_file) -          diff_file.highlighted_diff_lines = Gitlab::Diff::Highlight.new(diff_file, repository: diff_file.repository).highlight -          diff_file -        end -          def highlight_diff_file_from_cache!(diff_file, cache_diff_lines)            diff_file.highlighted_diff_lines = cache_diff_lines.map do |line|              Gitlab::Diff::Line.init_from_hash(line) @@ -56,7 +53,6 @@ module Gitlab            if highlight_cache[file_path]              highlight_diff_file_from_cache!(diff_file, highlight_cache[file_path])            else -            highlight_diff_file!(diff_file)              highlight_cache[file_path] = diff_file.highlighted_diff_lines.map(&:to_hash)            end diff --git a/lib/gitlab/email/message/repository_push.rb b/lib/gitlab/email/message/repository_push.rb index 71213813e17..16491ede71b 100644 --- a/lib/gitlab/email/message/repository_push.rb +++ b/lib/gitlab/email/message/repository_push.rb @@ -35,13 +35,13 @@ module Gitlab          def commits            return unless compare -          @commits ||= Commit.decorate(compare.commits, project) +          @commits ||= compare.commits          end          def diffs            return unless compare -          @diffs ||= compare.diff_file_collection(diff_options: { max_files: 30 }, diff_refs: diff_refs).diff_files +          @diffs ||= compare.diff_file_collection(diff_options: { max_files: 30 }).diff_files          end          def diffs_count @@ -49,9 +49,7 @@ module Gitlab          end          def compare -          if @opts[:compare] -            Compare.decorate(@opts[:compare], project) -          end +          @opts[:compare] if @opts[:compare]          end          def diff_refs @@ -99,16 +97,18 @@ module Gitlab              if commits.length > 1                namespace_project_compare_url(project_namespace,                                              project, -                                            from: Commit.new(compare.base, project), -                                            to:   Commit.new(compare.head, project)) +                                            from: compare.start_commit, +                                            to:   compare.head_commit)              else                namespace_project_commit_url(project_namespace, -                                           project, commits.first) +                                           project, +                                           commits.first)              end            else              unless @action == :delete                namespace_project_tree_url(project_namespace, -                                         project, ref_name) +                                         project, +                                         ref_name)              end            end          end | 
