summaryrefslogtreecommitdiffstats
path: root/scripts/oe-git-archive
diff options
context:
space:
mode:
Diffstat (limited to 'scripts/oe-git-archive')
-rwxr-xr-xscripts/oe-git-archive21
1 files changed, 18 insertions, 3 deletions
diff --git a/scripts/oe-git-archive b/scripts/oe-git-archive
index 1805ab3260..ab19cb9aa3 100755
--- a/scripts/oe-git-archive
+++ b/scripts/oe-git-archive
@@ -83,7 +83,7 @@ def init_git_repo(path, no_create, bare):
83 return repo 83 return repo
84 84
85 85
86def git_commit_data(repo, data_dir, branch, message, exclude): 86def git_commit_data(repo, data_dir, branch, message, exclude, notes):
87 """Commit data into a Git repository""" 87 """Commit data into a Git repository"""
88 log.info("Committing data into to branch %s", branch) 88 log.info("Committing data into to branch %s", branch)
89 tmp_index = os.path.join(repo.git_dir, 'index.oe-git-archive') 89 tmp_index = os.path.join(repo.git_dir, 'index.oe-git-archive')
@@ -106,6 +106,12 @@ def git_commit_data(repo, data_dir, branch, message, exclude):
106 git_cmd += ['-p', parent] 106 git_cmd += ['-p', parent]
107 commit = repo.run_cmd(git_cmd, env_update) 107 commit = repo.run_cmd(git_cmd, env_update)
108 108
109 # Create git notes
110 for ref, filename in notes:
111 ref = ref.format(branch_name=branch)
112 repo.run_cmd(['notes', '--ref', ref, 'add',
113 '-F', os.path.abspath(filename), commit])
114
109 # Update branch head 115 # Update branch head
110 git_cmd = ['update-ref', 'refs/heads/' + branch, commit] 116 git_cmd = ['update-ref', 'refs/heads/' + branch, commit]
111 if parent: 117 if parent:
@@ -191,6 +197,13 @@ def parse_args(argv):
191 parser.add_argument('--exclude', action='append', default=[], 197 parser.add_argument('--exclude', action='append', default=[],
192 help="Glob to exclude files from the commit. Relative " 198 help="Glob to exclude files from the commit. Relative "
193 "to DATA_DIR. May be specified multiple times") 199 "to DATA_DIR. May be specified multiple times")
200 parser.add_argument('--notes', nargs=2, action='append', default=[],
201 metavar=('GIT_REF', 'FILE'),
202 help="Add a file as a note under refs/notes/GIT_REF. "
203 "{branch_name} in GIT_REF will be expanded to the "
204 "actual target branch name (specified by "
205 "--branch-name). This option may be specified "
206 "multiple times.")
194 parser.add_argument('data_dir', metavar='DATA_DIR', 207 parser.add_argument('data_dir', metavar='DATA_DIR',
195 help="Data to commit") 208 help="Data to commit")
196 return parser.parse_args(argv) 209 return parser.parse_args(argv)
@@ -229,7 +242,7 @@ def main(argv=None):
229 242
230 # Commit data 243 # Commit data
231 commit = git_commit_data(data_repo, args.data_dir, branch_name, 244 commit = git_commit_data(data_repo, args.data_dir, branch_name,
232 commit_msg, args.exclude) 245 commit_msg, args.exclude, args.notes)
233 246
234 # Create tag 247 # Create tag
235 if tag_name: 248 if tag_name:
@@ -242,7 +255,9 @@ def main(argv=None):
242 # If no remote is given we push with the default settings from 255 # If no remote is given we push with the default settings from
243 # gitconfig 256 # gitconfig
244 if args.push is not True: 257 if args.push is not True:
245 cmd.extend([args.push, branch_name]) 258 notes_refs = ['refs/notes/' + ref.format(branch_name=branch_name)
259 for ref, _ in args.notes]
260 cmd.extend([args.push, branch_name] + notes_refs)
246 log.info("Pushing data to remote") 261 log.info("Pushing data to remote")
247 data_repo.run_cmd(cmd) 262 data_repo.run_cmd(cmd)
248 263