Fix setting author and committer
This commit is contained in:
parent
b7565b81a7
commit
efbd4fa1ef
2 changed files with 34 additions and 40 deletions
37
dist/src/create_pull_request.py
vendored
37
dist/src/create_pull_request.py
vendored
|
@ -18,16 +18,18 @@ DEFAULT_AUTHOR = (
|
||||||
|
|
||||||
|
|
||||||
def set_committer_author(repo, committer, author):
|
def set_committer_author(repo, committer, author):
|
||||||
# When the user intends for the committer and author to be the same,
|
# If either committer or author is supplied they will be cross used
|
||||||
# ideally, just the committer should be supplied. When just the author
|
|
||||||
# is supplied, the same user intention is assumed.
|
|
||||||
if committer is None and author is not None:
|
if committer is None and author is not None:
|
||||||
print("Supplied author will also be used as the committer.")
|
print("Supplied author will also be used as the committer.")
|
||||||
committer = author
|
committer = author
|
||||||
|
if author is None and committer is not None:
|
||||||
|
print("Supplied committer will also be used as the author.")
|
||||||
|
author = committer
|
||||||
|
|
||||||
# TODO Get committer and author from git config
|
# TODO If no overrides have been supplied, check if already set in config
|
||||||
# If just a committer exists, only set committer
|
# If not set, continue to use defaults
|
||||||
# If just author exists also use for the committer
|
# If set, return
|
||||||
|
# https://git-scm.com/docs/git-config#Documentation/git-config.txt-username
|
||||||
|
|
||||||
# Set defaults if no committer/author has been supplied
|
# Set defaults if no committer/author has been supplied
|
||||||
if committer is None and author is None:
|
if committer is None and author is None:
|
||||||
|
@ -36,20 +38,15 @@ def set_committer_author(repo, committer, author):
|
||||||
|
|
||||||
# Set git environment. This will not persist after the action completes.
|
# Set git environment. This will not persist after the action completes.
|
||||||
committer_name, committer_email = cmn.parse_display_name_email(committer)
|
committer_name, committer_email = cmn.parse_display_name_email(committer)
|
||||||
print(f"Configuring git committer as '{committer_name} <{committer_email}>'")
|
author_name, author_email = cmn.parse_display_name_email(author)
|
||||||
if author is not None:
|
repo.git.update_environment(
|
||||||
author_name, author_email = cmn.parse_display_name_email(author)
|
GIT_COMMITTER_NAME=committer_name,
|
||||||
print(f"Configuring git author as '{author_name} <{author_email}>'")
|
GIT_COMMITTER_EMAIL=committer_email,
|
||||||
repo.git.update_environment(
|
GIT_AUTHOR_NAME=author_name,
|
||||||
GIT_COMMITTER_NAME=committer_name,
|
GIT_AUTHOR_EMAIL=author_email,
|
||||||
GIT_COMMITTER_EMAIL=committer_email,
|
)
|
||||||
GIT_AUTHOR_NAME=author_name,
|
print(f"Configured git committer as '{committer_name} <{committer_email}>'")
|
||||||
GIT_AUTHOR_EMAIL=author_email,
|
print(f"Configured git author as '{author_name} <{author_email}>'")
|
||||||
)
|
|
||||||
else:
|
|
||||||
repo.git.update_environment(
|
|
||||||
GIT_COMMITTER_NAME=committer_name, GIT_COMMITTER_EMAIL=committer_email,
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
# Get required environment variables
|
# Get required environment variables
|
||||||
|
|
|
@ -18,16 +18,18 @@ DEFAULT_AUTHOR = (
|
||||||
|
|
||||||
|
|
||||||
def set_committer_author(repo, committer, author):
|
def set_committer_author(repo, committer, author):
|
||||||
# When the user intends for the committer and author to be the same,
|
# If either committer or author is supplied they will be cross used
|
||||||
# ideally, just the committer should be supplied. When just the author
|
|
||||||
# is supplied, the same user intention is assumed.
|
|
||||||
if committer is None and author is not None:
|
if committer is None and author is not None:
|
||||||
print("Supplied author will also be used as the committer.")
|
print("Supplied author will also be used as the committer.")
|
||||||
committer = author
|
committer = author
|
||||||
|
if author is None and committer is not None:
|
||||||
|
print("Supplied committer will also be used as the author.")
|
||||||
|
author = committer
|
||||||
|
|
||||||
# TODO Get committer and author from git config
|
# TODO If no overrides have been supplied, check if already set in config
|
||||||
# If just a committer exists, only set committer
|
# If not set, continue to use defaults
|
||||||
# If just author exists also use for the committer
|
# If set, return
|
||||||
|
# https://git-scm.com/docs/git-config#Documentation/git-config.txt-username
|
||||||
|
|
||||||
# Set defaults if no committer/author has been supplied
|
# Set defaults if no committer/author has been supplied
|
||||||
if committer is None and author is None:
|
if committer is None and author is None:
|
||||||
|
@ -36,20 +38,15 @@ def set_committer_author(repo, committer, author):
|
||||||
|
|
||||||
# Set git environment. This will not persist after the action completes.
|
# Set git environment. This will not persist after the action completes.
|
||||||
committer_name, committer_email = cmn.parse_display_name_email(committer)
|
committer_name, committer_email = cmn.parse_display_name_email(committer)
|
||||||
print(f"Configuring git committer as '{committer_name} <{committer_email}>'")
|
author_name, author_email = cmn.parse_display_name_email(author)
|
||||||
if author is not None:
|
repo.git.update_environment(
|
||||||
author_name, author_email = cmn.parse_display_name_email(author)
|
GIT_COMMITTER_NAME=committer_name,
|
||||||
print(f"Configuring git author as '{author_name} <{author_email}>'")
|
GIT_COMMITTER_EMAIL=committer_email,
|
||||||
repo.git.update_environment(
|
GIT_AUTHOR_NAME=author_name,
|
||||||
GIT_COMMITTER_NAME=committer_name,
|
GIT_AUTHOR_EMAIL=author_email,
|
||||||
GIT_COMMITTER_EMAIL=committer_email,
|
)
|
||||||
GIT_AUTHOR_NAME=author_name,
|
print(f"Configured git committer as '{committer_name} <{committer_email}>'")
|
||||||
GIT_AUTHOR_EMAIL=author_email,
|
print(f"Configured git author as '{author_name} <{author_email}>'")
|
||||||
)
|
|
||||||
else:
|
|
||||||
repo.git.update_environment(
|
|
||||||
GIT_COMMITTER_NAME=committer_name, GIT_COMMITTER_EMAIL=committer_email,
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
# Get required environment variables
|
# Get required environment variables
|
||||||
|
|
Loading…
Reference in a new issue