- tree = c.captureOutput(['git', 'ls-tree', branch],
- cwd=superproject).strip()
+ tree = logAndRun(['git', 'ls-tree', branch],
+ cwd=superproject).strip()
+
+ tree_items = dict(k, v for v, k in (x.split("\t" for x in tree.split("\n"))))
+
+ created = not (package in tree_items)
+
+ tree_items[package] = "160000 commit "+commit
+
+ # If "created" is true, we need to check if the package is
+ # mentioned in .gitmodules, and add it if not.
+ if created:
+ gitmodules = c.captureOutput(['git', 'cat-file', 'blob', '%s:.gitmodules' % (branch)],
+ cwd=superproject)
+ if ('[submodule "%s"]' % (package)) not in gitmodules.split("\n"):
+ gitmodules += """[submodule "%s"]
+\tpath = %s
+\turl = ../packages/%s.git
+""" % (package, package, package)
+ gitmodules_hash = c.captureOutput(['git', 'hash-object', '-w', '--stdin'],
+ cwd=superproject).strip()
+ tree_items[package] = "100644 blob "+gitmodules_hash