1 """Function/variables commmon to all the commands
5 Copyright (C) 2005, Catalin Marinas <catalin.marinas@gmail.com>
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License version 2 as
9 published by the Free Software Foundation.
11 This program is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with this program; if not, write to the Free Software
18 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
22 from optparse
import OptionParser
, make_option
24 from stgit
.utils
import *
25 from stgit
import stack
, git
28 # Command exception class
29 class CmdException(Exception):
40 string_list
= string
.split('/')
42 if len(string_list
) == 1:
44 git_id
= string_list
[0]
49 return read_string(crt_series
.get_base_file())
51 for path
in [os
.path
.join(git
.base_dir
, 'refs', 'heads'),
52 os
.path
.join(git
.base_dir
, 'refs', 'tags')]:
53 id_file
= os
.path
.join(path
, git_id
)
54 if os
.path
.isfile(id_file
):
55 return read_string(id_file
)
56 elif len(string_list
) == 2:
57 patch_name
= string_list
[0]
59 patch_name
= crt_series
.get_current()
60 git_id
= string_list
[1]
63 raise CmdException
, 'No patches applied'
64 elif not (patch_name
in crt_series
.get_applied()
65 + crt_series
.get_unapplied()):
66 raise CmdException
, 'Unknown patch "%s"' % patch_name
68 if git_id
== 'bottom':
69 return crt_series
.get_patch(patch_name
).get_bottom()
71 return crt_series
.get_patch(patch_name
).get_top()
73 raise CmdException
, 'Unknown id: %s' % string
75 def check_local_changes():
76 if git
.local_changes():
78 'local changes in the tree. Use "refresh" to commit them'
80 def check_head_top_equal():
81 if not crt_series
.head_top_equal():
83 'HEAD and top are not the same. You probably committed\n' \
84 ' changes to the tree ouside of StGIT. If you know what you\n' \
85 ' are doing, use the "refresh -f" command'
87 def check_conflicts():
88 if os
.path
.exists(os
.path
.join(git
.base_dir
, 'conflicts')):
89 raise CmdException
, 'Unsolved conflicts. Please resolve them first'
91 def print_crt_patch():
92 patch
= crt_series
.get_current()
94 print 'Now at patch "%s"' % patch
96 print 'No patches applied'
98 def resolved(filename
):
99 git
.update_cache([filename
])
100 for ext
in ['.local', '.older', '.remote']:
102 if os
.path
.isfile(fn
):
106 conflicts
= git
.get_conflicts()
108 for filename
in conflicts
:
110 os
.remove(os
.path
.join(git
.base_dir
, 'conflicts'))
112 def name_email(string
):
113 """Return a tuple consisting of the name and email parsed from a
114 standard 'name <email>' string
116 names
= re
.split('([^<>]*)<([^<>]*)>', string
)
118 raise CmdException
, 'Incorrect "name <email>" string: %s' % string
120 return tuple([names
[1].strip(), names
[2].strip()])