Plugins/VcsPlugins/vcsMercurial/hg.py

branch
5_5_x
changeset 3671
e8a37c412d28
parent 3591
2f2a4a76dd22
child 3854
219087ed6118
diff -r 3eb59ee5a837 -r e8a37c412d28 Plugins/VcsPlugins/vcsMercurial/hg.py
--- a/Plugins/VcsPlugins/vcsMercurial/hg.py	Fri Jul 04 19:57:23 2014 +0200
+++ b/Plugins/VcsPlugins/vcsMercurial/hg.py	Sat Jul 05 12:23:15 2014 +0200
@@ -1186,17 +1186,18 @@
         
         if output:
             for line in output.splitlines():
-                flag, path = line.split(" ", 1)
-                absname = os.path.join(repodir, os.path.normcase(path))
-                if flag not in "?I":
-                    if fname == '.':
-                        if absname.startswith(dname + os.path.sep):
-                            return self.canBeCommitted
-                        if absname == dname:
-                            return self.canBeCommitted
-                    else:
-                        if absname == name:
-                            return self.canBeCommitted
+                if line and line[0] in "MARC!?I":
+                    flag, path = line.split(" ", 1)
+                    absname = os.path.join(repodir, os.path.normcase(path))
+                    if flag not in "?I":
+                        if fname == '.':
+                            if absname.startswith(dname + os.path.sep):
+                                return self.canBeCommitted
+                            if absname == dname:
+                                return self.canBeCommitted
+                        else:
+                            if absname == name:
+                                return self.canBeCommitted
         
         return self.canBeAdded
     
@@ -1254,28 +1255,29 @@
             if output:
                 dirs = [x for x in names.keys() if os.path.isdir(x)]
                 for line in output.splitlines():
-                    flag, path = line.split(" ", 1)
-                    name = os.path.normcase(os.path.join(repodir, path))
-                    dirName = os.path.dirname(name)
-                    if name.startswith(dname):
+                    if line and line[0] in "MARC!?I":
+                        flag, path = line.split(" ", 1)
+                        name = os.path.normcase(os.path.join(repodir, path))
+                        dirName = os.path.dirname(name)
+                        if name.startswith(dname):
+                            if flag not in "?I":
+                                if name in names:
+                                    names[name] = self.canBeCommitted
+                                if dirName in names:
+                                    names[dirName] = self.canBeCommitted
+                                if dirs:
+                                    for d in dirs:
+                                        if name.startswith(d):
+                                            names[d] = self.canBeCommitted
+                                            dirs.remove(d)
+                                            break
                         if flag not in "?I":
-                            if name in names:
-                                names[name] = self.canBeCommitted
-                            if dirName in names:
-                                names[dirName] = self.canBeCommitted
-                            if dirs:
-                                for d in dirs:
-                                    if name.startswith(d):
-                                        names[d] = self.canBeCommitted
-                                        dirs.remove(d)
-                                        break
-                    if flag not in "?I":
-                        self.statusCache[name] = self.canBeCommitted
-                        self.statusCache[dirName] = self.canBeCommitted
-                    else:
-                        self.statusCache[name] = self.canBeAdded
-                        if dirName not in self.statusCache:
-                            self.statusCache[dirName] = self.canBeAdded
+                            self.statusCache[name] = self.canBeCommitted
+                            self.statusCache[dirName] = self.canBeCommitted
+                        else:
+                            self.statusCache[name] = self.canBeAdded
+                            if dirName not in self.statusCache:
+                                self.statusCache[dirName] = self.canBeAdded
         
         return names
     

eric ide

mercurial