~abentley/bzrtools/bzrtools.dev

« back to all changes in this revision

Viewing changes to patch.py

  • Committer: Aaron Bentley
  • Date: 2006-12-12 16:50:31 UTC
  • Revision ID: abentley@panoramicfeedback.com-20061212165031-51w8gjy1eps1vnw0
update NEWS

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2005, 2008 Aaron Bentley, 2006 Michael Ellerman
2
 
# <aaron@aaronbentley.com>
 
1
# Copyright (C) 2005 Aaron Bentley
 
2
# <aaron.bentley@utoronto.ca>
3
3
#
4
4
#    This program is free software; you can redistribute it and/or modify
5
5
#    it under the terms of the GNU General Public License as published by
15
15
#    along with this program; if not, write to the Free Software
16
16
#    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
17
17
import sys
18
 
import subprocess
 
18
from subprocess import Popen, PIPE
 
19
from urlparse import urlsplit, urlunsplit
19
20
 
 
21
from bzrlib import urlutils
 
22
from bzrlib.transport import get_transport
 
23
from bzrlib.workingtree import WorkingTree
20
24
import bzrlib.add
21
25
 
22
 
from bzrlib.plugins.bzrtools.bzrtools import open_from_url
23
 
from errors import PatchFailed, PatchInvokeError
24
 
 
25
 
def patch(tree, location, strip, quiet=False):
 
26
def patch(tree, location, strip):
26
27
    """Apply a patch to a branch, using patch(1).  URLs may be used."""
27
28
    my_file = None
28
29
    if location is None:
29
30
        my_file = sys.stdin
30
31
    else:
31
 
        my_file = open_from_url(location)
32
 
    patches = [my_file.read()]
33
 
    return run_patch(tree.basedir, patches, strip, quiet=quiet)
34
 
 
35
 
 
36
 
def run_patch(directory, patches, strip=0, reverse=False, dry_run=False,
37
 
              quiet=False, _patch_cmd='patch', target_file=None):
38
 
    args = [_patch_cmd, '-d', directory, '-s', '-p%d' % strip, '-f']
39
 
    if quiet:
40
 
        args.append('--quiet')
41
 
 
42
 
    if sys.platform == "win32":
43
 
        args.append('--binary')
44
 
 
45
 
    if reverse:
46
 
        args.append('-R')
47
 
    if dry_run:
48
 
        if sys.platform.startswith('freebsd'):
49
 
            args.append('--check')
50
 
        else:
51
 
            args.append('--dry-run')
52
 
        stderr = subprocess.PIPE
53
 
    else:
54
 
        stderr = None
55
 
    if target_file is not None:
56
 
        args.append(target_file)
57
 
 
58
 
    try:
59
 
        process = subprocess.Popen(args, stdin=subprocess.PIPE,
60
 
                                   stdout=subprocess.PIPE, stderr=stderr)
61
 
    except OSError, e:
62
 
        raise PatchInvokeError(e)
63
 
    try:
64
 
        for patch in patches:
65
 
            process.stdin.write(str(patch))
66
 
        process.stdin.close()
67
 
 
68
 
    except IOError, e:
69
 
        raise PatchInvokeError(e, process.stderr.read())
70
 
 
71
 
    result = process.wait()
72
 
    if not dry_run:
73
 
        sys.stdout.write(process.stdout.read())
74
 
    if result != 0:
75
 
        raise PatchFailed()
76
 
 
77
 
    return result
 
32
        location = urlutils.normalize_url(location)
 
33
        (scheme, loc, path, query, fragment) = urlsplit(location)
 
34
        loc_start = urlunsplit((scheme, loc, '/', '', ''))
 
35
        my_file = get_transport(loc_start).get(path[1:])
 
36
    cmd = ['patch', '--directory', tree.basedir, '--strip', str(strip)]
 
37
    r = 0
 
38
    child_proc = Popen(cmd, stdin=PIPE)
 
39
    for line in my_file:
 
40
        child_proc.stdin.write(line)
 
41
    child_proc.stdin.close()
 
42
    r = child_proc.wait()
 
43
    return r