This patch adds a number of assertions to document and verify the
complex restrictions of the input parameters to the Series.new_patch
function. It also adds the requirement that 'before_existing' and
'commit' cannot be true at the same time when calling it, instead of
updating 'commit' inside the function.
Signed-off-by: David Kågedal <davidk@lysator.liu.se>
Signed-off-by: Karl Hasselström <kha@treskal.com>
name_email_date(commit.get_author())
crt_series.new_patch(patchname,
can_edit = False, before_existing = True,
name_email_date(commit.get_author())
crt_series.new_patch(patchname,
can_edit = False, before_existing = True,
top = commit_id, bottom = parent,
message = commit.get_log(),
author_name = author_name,
top = commit_id, bottom = parent,
message = commit.get_log(),
author_name = author_name,
author_name = None, author_email = None, author_date = None,
committer_name = None, committer_email = None,
before_existing = False):
author_name = None, author_email = None, author_date = None,
committer_name = None, committer_email = None,
before_existing = False):
+ """Creates a new patch, either pointing to an existing commit object,
+ or by creating a new commit object.
+ assert commit or (top and bottom)
+ assert not before_existing or (top and bottom)
+ assert not (commit and before_existing)
+ assert (top and bottom) or (not top and not bottom)
+ assert not top or (bottom == git.get_commit(top).get_parent())
+
if name != None:
self.__patch_name_valid(name)
if self.patch_exists(name):
if name != None:
self.__patch_name_valid(name)
if self.patch_exists(name):
if before_existing:
insert_string(self.__applied_file, patch.get_name())
if before_existing:
insert_string(self.__applied_file, patch.get_name())
- # no need to commit anything as the object is already
- # present (mainly used by 'uncommit')
- commit = False
elif unapplied:
patches = [patch.get_name()] + self.get_unapplied()
write_strings(self.__unapplied_file, patches)
elif unapplied:
patches = [patch.get_name()] + self.get_unapplied()
write_strings(self.__unapplied_file, patches)
committer_email = committer_email)
# set the patch top to the new commit
patch.set_top(commit_id)
committer_email = committer_email)
# set the patch top to the new commit
patch.set_top(commit_id)
+ else:
+ assert top != bottom
self.log_patch(patch, 'new')
self.log_patch(patch, 'new')