~abentley/bzrtools/bzrtools.dev

« back to all changes in this revision

Viewing changes to shelf.py

  • Committer: Aaron Bentley
  • Date: 2006-06-18 01:24:25 UTC
  • mfrom: (0.3.3 shelf-dev)
  • Revision ID: aaron.bentley@utoronto.ca-20060618012425-61c3d9d62a2cc971
Merged the latest Shelf changes, patches.py no longer needed.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
#!/usr/bin/python
 
2
 
1
3
import os
2
4
import sys
3
5
import subprocess
4
6
from datetime import datetime
5
 
from errors import CommandError, PatchFailed, PatchInvokeError
 
7
from errors import CommandError, PatchFailed
6
8
from hunk_selector import ShelveHunkSelector, UnshelveHunkSelector
7
9
from patchsource import PatchSource, FilePatchSource
8
 
from bzrlib.osutils import rename
9
10
 
10
11
class Shelf(object):
11
12
    MESSAGE_PREFIX = "# Shelved patch: "
55
56
 
56
57
    def delete(self, patch):
57
58
        path = self.__path_from_user(patch)
58
 
        rename(path, '%s~' % path)
 
59
        os.rename(path, '%s~' % path)
59
60
 
60
61
    def display(self, patch=None):
61
62
        if patch is None:
132
133
            return None
133
134
        return patch[len(self.MESSAGE_PREFIX):patch.index('\n')]
134
135
 
135
 
    def unshelve(self, patch_source, patch_name=None, all=False, force=False,
136
 
                 no_color=False):
 
136
    def unshelve(self, patch_source, patch_name=None, all=False, force=False):
137
137
        self._check_upgrade()
138
138
 
139
 
        if no_color is False:
140
 
            color = None
141
 
        else:
142
 
            color = False
143
139
        if patch_name is None:
144
140
            patch_path = self.last_patch()
145
141
        else:
153
149
            to_unshelve = patches
154
150
            to_remain = []
155
151
        else:
156
 
            hs = UnshelveHunkSelector(patches, color)
157
 
            to_unshelve, to_remain = hs.select()
 
152
            to_unshelve, to_remain = UnshelveHunkSelector(patches).select()
158
153
 
159
154
        if len(to_unshelve) == 0:
160
155
            raise CommandError('Nothing to unshelve')
185
180
                    "longer applies cleanly to the working tree!")
186
181
 
187
182
        # Backup the shelved patch
188
 
        rename(patch_path, '%s~' % patch_path)
 
183
        os.rename(patch_path, '%s~' % patch_path)
189
184
 
190
185
        if len(to_remain) > 0:
191
186
            f = open(patch_path, 'w')
193
188
                f.write(str(patch))
194
189
            f.close()
195
190
 
196
 
    def shelve(self, patch_source, all=False, message=None, no_color=False):
 
191
    def shelve(self, patch_source, all=False, message=None):
197
192
        self._check_upgrade()
198
 
        if no_color is False:
199
 
            color = None
200
 
        else:
201
 
            color = False
202
193
 
203
194
        patches = patch_source.readpatches()
204
195
 
205
196
        if all:
206
197
            to_shelve = patches
207
198
        else:
208
 
            to_shelve = ShelveHunkSelector(patches, color).select()[0]
 
199
            to_shelve = ShelveHunkSelector(patches).select()[0]
209
200
 
210
201
        if len(to_shelve) == 0:
211
202
            raise CommandError('Nothing to shelve')
243
234
 
244
235
    def _run_patch(self, patches, strip=0, reverse=False, dry_run=False):
245
236
        args = ['patch', '-d', self.base, '-s', '-p%d' % strip, '-f']
246
 
 
247
 
        if sys.platform == "win32":
248
 
            args.append('--binary')
249
 
 
250
237
        if reverse:
251
238
            args.append('-R')
252
239
        if dry_run:
255
242
        else:
256
243
            stdout = stderr = None
257
244
 
258
 
        try:
259
 
            process = subprocess.Popen(args, stdin=subprocess.PIPE,
260
 
                                       stdout=stdout, stderr=stderr)
261
 
            for patch in patches:
262
 
                process.stdin.write(str(patch))
263
 
 
264
 
        except IOError, e:
265
 
            raise PatchInvokeError(e, process.stderr.read())
 
245
        process = subprocess.Popen(args, stdin=subprocess.PIPE, stdout=stdout,
 
246
                        stderr=stderr)
 
247
        for patch in patches:
 
248
            process.stdin.write(str(patch))
266
249
 
267
250
        process.communicate()
268
251
 
327
310
            new_file.close()
328
311
            self.log('Copied %s to %s/%s\n' % (os.path.basename(patch),
329
312
                self.name, os.path.basename(new_path)))
330
 
            rename(patch, patch + '~')
 
313
            os.rename(patch, patch + '~')