[PATCH] D128243: [BOLT][UTILS] Add nfc-check-setup --switch-back option

Amir Ayupov via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Mon Jun 20 23:48:16 PDT 2022


Amir created this revision.
Herald added a reviewer: rafauler.
Herald added a subscriber: ayermolo.
Herald added a reviewer: maksfb.
Herald added a project: All.
Amir requested review of this revision.
Herald added subscribers: llvm-commits, yota9.
Herald added a project: LLVM.

Add an option to switch repo revision back, handling stashing automatically.


Repository:
  rG LLVM Github Monorepo

https://reviews.llvm.org/D128243

Files:
  bolt/utils/nfc-check-setup.py


Index: bolt/utils/nfc-check-setup.py
===================================================================
--- bolt/utils/nfc-check-setup.py
+++ bolt/utils/nfc-check-setup.py
@@ -26,7 +26,10 @@
             Passes the options through to llvm-bolt-wrapper.
             '''))
     parser.add_argument('build_dir', nargs='?', default=os.getcwd(),
-                        help='Path to BOLT build directory, default is current directory')
+                        help='Path to BOLT build directory, default is current '
+                             'directory')
+    parser.add_argument('--switch-back', default=False, action='store_true',
+                        help='Checkout back to the starting revision')
     args, wrapper_args = parser.parse_known_args()
     bolt_path = f'{args.build_dir}/bin/llvm-bolt'
 
@@ -50,8 +53,13 @@
     # memorize the old hash for logging
     old_ref = get_git_ref_or_rev(source_dir)
 
-    # save local changes before checkout
-    subprocess.run(shlex.split("git stash"), cwd=source_dir)
+    # determine whether a stash is needed
+    stash = subprocess.run(shlex.split("git status --porcelain"), cwd=source_dir,
+                           stdout=subprocess.PIPE, stderr=subprocess.STDOUT,
+                           text=True).stdout
+    if stash:
+        # save local changes before checkout
+        subprocess.run(shlex.split("git stash"), cwd=source_dir)
     # check out the previous commit
     subprocess.run(shlex.split("git checkout -f HEAD^"), cwd=source_dir)
     # get the parent commit hash for logging
@@ -65,17 +73,22 @@
     ini = subprocess.check_output(
         shlex.split(
             f"{wrapper_path} {bolt_path}.old {bolt_path}.new") + wrapper_args,
-        text=True)
+            text=True)
     with open(f'{args.build_dir}/bin/llvm-bolt-wrapper.ini', 'w') as f:
         f.write(ini)
     # symlink llvm-bolt-wrapper
     os.symlink(wrapper_path, bolt_path)
-    print(f"The repository {source_dir} has been switched from rev {old_ref} "
-          f"to {new_ref}. Local changes were stashed. Switch back using\n\t"
-          f"git checkout {old_ref}\n"
-          "Current build directory is ready to run BOLT tests, e.g.\n\t"
-          "bin/llvm-lit -sv tools/bolt/test\nor\n\t"
-          "bin/llvm-lit -sv tools/bolttests")
+    if args.switch_back:
+        if stash:
+            subprocess.run(shlex.split("git stash pop"), cwd=source_dir)
+        subprocess.run(shlex.split(f"git checkout {old_ref}"), cwd=source_dir)
+    else:
+        print(f"The repository {source_dir} has been switched from {old_ref} "
+              f"to {new_ref}. Local changes were stashed. Switch back using\n\t"
+              f"git checkout {old_ref}\n")
+    print(f"Build directory {args.build_dir} is ready to run BOLT tests, e.g.\n"
+          "\tbin/llvm-lit -sv tools/bolt/test\nor\n"
+          "\tbin/llvm-lit -sv tools/bolttests")
 
 
 if __name__ == "__main__":


-------------- next part --------------
A non-text attachment was scrubbed...
Name: D128243.438568.patch
Type: text/x-patch
Size: 2937 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20220621/24d9eb27/attachment.bin>


More information about the llvm-commits mailing list