Commit fff3c526 authored by Lin Jen-Shin's avatar Lin Jen-Shin

Use multi_action to commit which doesn't need to

have the branch existed upfront. That is,
`Rugged::Commit.create` rather than `Gitlab::Git::Blob.commit`
which the former doesn't need to have the branch but the latter
needs.
parent 5ba468ef
...@@ -773,27 +773,17 @@ class Repository ...@@ -773,27 +773,17 @@ class Repository
user, path, content, message, branch, update, user, path, content, message, branch, update,
author_email: nil, author_name: nil, author_email: nil, author_name: nil,
source_branch: nil, source_project: project) source_branch: nil, source_project: project)
GitOperationService.new(user, self).with_branch( multi_action(
branch, user: user,
branch: branch,
message: message,
author_email: author_email,
author_name: author_name,
source_branch: source_branch, source_branch: source_branch,
source_project: source_project) do |ref| source_project: source_project,
options = { actions: [{action: :create,
commit: { file_path: path,
branch: ref, content: content}])
message: message,
update_ref: false
},
file: {
content: content,
path: path,
update: update
}
}
options.merge!(get_committer_and_author(user, email: author_email, name: author_name))
Gitlab::Git::Blob.commit(raw_repository, options)
end
end end
# rubocop:enable Metrics/ParameterLists # rubocop:enable Metrics/ParameterLists
...@@ -803,32 +793,24 @@ class Repository ...@@ -803,32 +793,24 @@ class Repository
branch:, previous_path:, message:, branch:, previous_path:, message:,
author_email: nil, author_name: nil, author_email: nil, author_name: nil,
source_branch: nil, source_project: project) source_branch: nil, source_project: project)
GitOperationService.new(user, self).with_branch( action = if previous_path && previous_path != path
branch, :move
else
:update
end
multi_action(
user: user,
branch: branch,
message: message,
author_email: author_email,
author_name: author_name,
source_branch: source_branch, source_branch: source_branch,
source_project: source_project) do |ref| source_project: source_project,
options = { actions: [{action: action,
commit: { file_path: path,
branch: ref, content: content,
message: message, previous_path: previous_path}])
update_ref: false
},
file: {
content: content,
path: path,
update: true
}
}
options.merge!(get_committer_and_author(user, email: author_email, name: author_name))
if previous_path && previous_path != path
options[:file][:previous_path] = previous_path
Gitlab::Git::Blob.rename(raw_repository, options)
else
Gitlab::Git::Blob.commit(raw_repository, options)
end
end
end end
# rubocop:enable Metrics/ParameterLists # rubocop:enable Metrics/ParameterLists
...@@ -837,25 +819,16 @@ class Repository ...@@ -837,25 +819,16 @@ class Repository
user, path, message, branch, user, path, message, branch,
author_email: nil, author_name: nil, author_email: nil, author_name: nil,
source_branch: nil, source_project: project) source_branch: nil, source_project: project)
GitOperationService.new(user, self).with_branch( multi_action(
branch, user: user,
branch: branch,
message: message,
author_email: author_email,
author_name: author_name,
source_branch: source_branch, source_branch: source_branch,
source_project: source_project) do |ref| source_project: source_project,
options = { actions: [{action: :delete,
commit: { file_path: path}])
branch: ref,
message: message,
update_ref: false
},
file: {
path: path
}
}
options.merge!(get_committer_and_author(user, email: author_email, name: author_name))
Gitlab::Git::Blob.remove(raw_repository, options)
end
end end
# rubocop:enable Metrics/ParameterLists # rubocop:enable Metrics/ParameterLists
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment