debian-mirror-gitlab/app/serializers/diff_file_entity.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

103 lines
3.2 KiB
Ruby
Raw Normal View History

2018-11-18 11:00:15 +05:30
# frozen_string_literal: true
2019-02-15 15:39:39 +05:30
class DiffFileEntity < DiffFileBaseEntity
2021-10-27 15:23:28 +05:30
include DiffFileConflictType
2018-11-08 19:23:39 +05:30
include CommitsHelper
2018-03-27 19:54:05 +05:30
include IconsHelper
2021-01-29 00:20:46 +05:30
include Gitlab::Utils::StrongMemoize
2018-03-27 19:54:05 +05:30
2018-11-08 19:23:39 +05:30
expose :added_lines
expose :removed_lines
2019-07-07 11:18:12 +05:30
expose :load_collapsed_diff_url, if: -> (diff_file, options) { options[:merge_request] } do |diff_file|
2018-11-08 19:23:39 +05:30
merge_request = options[:merge_request]
project = merge_request.target_project
next unless project
diff_for_path_namespace_project_merge_request_path(
namespace_id: project.namespace.to_param,
project_id: project.to_param,
id: merge_request.iid,
old_path: diff_file.old_path,
new_path: diff_file.new_path,
file_identifier: diff_file.file_identifier
)
end
expose :view_path, if: -> (_, options) { options[:merge_request] } do |diff_file|
merge_request = options[:merge_request]
project = merge_request.target_project
next unless project
next unless diff_file.content_sha
project_blob_path(project, tree_join(diff_file.content_sha, diff_file.new_path))
end
expose :replaced_view_path, if: -> (_, options) { options[:merge_request] } do |diff_file|
image_diff = diff_file.rich_viewer && diff_file.rich_viewer.partial_name == 'image'
image_replaced = diff_file.old_content_sha && diff_file.old_content_sha != diff_file.content_sha
merge_request = options[:merge_request]
project = merge_request.target_project
next unless project
project_blob_path(project, tree_join(diff_file.old_content_sha, diff_file.old_path)) if image_diff && image_replaced
end
expose :context_lines_path, if: -> (diff_file, _) { diff_file.text? } do |diff_file|
next unless diff_file.content_sha
project_blob_diff_path(diff_file.repository.project, tree_join(diff_file.content_sha, diff_file.file_path))
end
# Used for inline diffs
2021-04-29 21:17:54 +05:30
expose :highlighted_diff_lines, using: DiffLineEntity, if: -> (diff_file, options) { inline_diff_view?(options) && diff_file.text? } do |diff_file|
2022-07-23 23:45:48 +05:30
highlighted_diff_lines_for(diff_file, options)
2018-11-08 19:23:39 +05:30
end
2019-07-07 11:18:12 +05:30
expose :is_fully_expanded do |diff_file|
2021-01-29 00:20:46 +05:30
if conflict_file(options, diff_file)
false
else
diff_file.fully_expanded?
end
2019-07-07 11:18:12 +05:30
end
2018-11-08 19:23:39 +05:30
# Used for parallel diffs
2021-04-29 21:17:54 +05:30
expose :parallel_diff_lines, using: DiffLineParallelEntity, if: -> (diff_file, options) { parallel_diff_view?(options) && diff_file.text? }
2019-12-26 22:10:19 +05:30
2020-04-22 19:07:51 +05:30
expose :code_navigation_path, if: -> (diff_file) { options[:code_navigation_path] } do |diff_file|
options[:code_navigation_path].full_json_path_for(diff_file.new_path)
end
2019-12-26 22:10:19 +05:30
private
2021-04-29 21:17:54 +05:30
def parallel_diff_view?(options)
diff_view(options) == :parallel
2019-12-26 22:10:19 +05:30
end
2021-04-29 21:17:54 +05:30
def inline_diff_view?(options)
diff_view(options) == :inline
end
def diff_view(options)
2019-12-26 22:10:19 +05:30
# If nothing is present, inline will be the default.
2021-04-29 21:17:54 +05:30
options.fetch(:diff_view, :inline).to_sym
2019-12-26 22:10:19 +05:30
end
2022-07-23 23:45:48 +05:30
def highlighted_diff_lines_for(diff_file, options)
file = conflict_file(options, diff_file) || diff_file
file.diff_lines_for_serializer
rescue Gitlab::Git::Conflict::Parser::UnmergeableFile
# Fallback to diff_file as it means that conflict lines can't be parsed due to limit
diff_file.diff_lines_for_serializer
end
2018-03-27 19:54:05 +05:30
end
2022-01-26 12:08:38 +05:30
DiffFileEntity.prepend_mod