chiark / gitweb /
Allow 'import' to cherry-pick a commit object
[stgit] / stgit / commands / common.py
index c4ddc945e46bbef26d40509232abf98106df0e0a..c6d45351a0932870d8187c310212d44dcbfd6fa6 100644 (file)
@@ -100,7 +100,7 @@ def print_crt_patch():
         print 'No patches applied'
 
 def resolved(filename):
-    git.update_cache([filename])
+    git.update_cache([filename], force = True)
     for ext in ['.local', '.older', '.remote']:
         fn = filename + ext
         if os.path.isfile(fn):
@@ -117,8 +117,18 @@ def name_email(string):
     """Return a tuple consisting of the name and email parsed from a
     standard 'name <email>' string
     """
-    names = re.split('([^<>]*)<([^<>]*)>', string)
-    if len(names) != 4:
+    str_list = re.findall('^(.*)\s+<(.*)>$', string)
+    if not str_list:
         raise CmdException, 'Incorrect "name <email>" string: %s' % string
 
-    return tuple([names[1].strip(), names[2].strip()])
+    return str_list[0]
+
+def name_email_date(string):
+    """Return a tuple consisting of the name, email and date parsed
+    from a 'name <email> date' string
+    """
+    str_list = re.findall('^(.*)\s+<(.*)>\s+(.*)$', string)
+    if not str_list:
+        raise CmdException, 'Incorrect "name <email> date" string: %s' % string
+
+    return str_list[0]