/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

Viewing changes to bzrlib/diff.py

  • Committer: Parth Malwankar
  • Date: 2010-04-19 13:23:53 UTC
  • mfrom: (5165 +trunk)
  • mto: (5183.1.1 integration)
  • mto: This revision was merged to the branch mainline in revision 5184.
  • Revision ID: parth.malwankar@gmail.com-20100419132353-gwp4r4srafq2i2kb
merged in trunk and moved NEWS entry to 2.2b2

Show diffs side-by-side

added added

removed removed

Lines of Context:
32
32
    branch as _mod_branch,
33
33
    bzrdir,
34
34
    cmdline,
 
35
    cleanup,
35
36
    errors,
36
37
    osutils,
37
38
    patiencediff,
43
44
from bzrlib.workingtree import WorkingTree
44
45
""")
45
46
 
 
47
from bzrlib.registry import (
 
48
    Registry,
 
49
    )
46
50
from bzrlib.symbol_versioning import (
47
51
    deprecated_function,
 
52
    deprecated_in,
48
53
    )
49
54
from bzrlib.trace import mutter, note, warning
50
55
 
286
291
                        new_abspath, e)
287
292
 
288
293
 
 
294
@deprecated_function(deprecated_in((2, 2, 0)))
289
295
def get_trees_and_branches_to_diff(path_list, revision_specs, old_url, new_url,
290
296
                                   apply_view=True):
291
297
    """Get the trees and specific files to diff given a list of paths.
310
316
    :returns:
311
317
        a tuple of (old_tree, new_tree, old_branch, new_branch,
312
318
        specific_files, extra_trees) where extra_trees is a sequence of
313
 
        additional trees to search in for file-ids.
 
319
        additional trees to search in for file-ids.  The trees and branches
 
320
        are not locked.
 
321
    """
 
322
    op = cleanup.OperationWithCleanups(get_trees_and_branches_to_diff_locked)
 
323
    return op.run_simple(path_list, revision_specs, old_url, new_url,
 
324
            op.add_cleanup, apply_view=apply_view)
 
325
    
 
326
 
 
327
def get_trees_and_branches_to_diff_locked(
 
328
    path_list, revision_specs, old_url, new_url, add_cleanup, apply_view=True):
 
329
    """Get the trees and specific files to diff given a list of paths.
 
330
 
 
331
    This method works out the trees to be diff'ed and the files of
 
332
    interest within those trees.
 
333
 
 
334
    :param path_list:
 
335
        the list of arguments passed to the diff command
 
336
    :param revision_specs:
 
337
        Zero, one or two RevisionSpecs from the diff command line,
 
338
        saying what revisions to compare.
 
339
    :param old_url:
 
340
        The url of the old branch or tree. If None, the tree to use is
 
341
        taken from the first path, if any, or the current working tree.
 
342
    :param new_url:
 
343
        The url of the new branch or tree. If None, the tree to use is
 
344
        taken from the first path, if any, or the current working tree.
 
345
    :param add_cleanup:
 
346
        a callable like Command.add_cleanup.  get_trees_and_branches_to_diff
 
347
        will register cleanups that must be run to unlock the trees, etc.
 
348
    :param apply_view:
 
349
        if True and a view is set, apply the view or check that the paths
 
350
        are within it
 
351
    :returns:
 
352
        a tuple of (old_tree, new_tree, old_branch, new_branch,
 
353
        specific_files, extra_trees) where extra_trees is a sequence of
 
354
        additional trees to search in for file-ids.  The trees and branches
 
355
        will be read-locked until the cleanups registered via the add_cleanup
 
356
        param are run.
314
357
    """
315
358
    # Get the old and new revision specs
316
359
    old_revision_spec = None
339
382
        default_location = path_list[0]
340
383
        other_paths = path_list[1:]
341
384
 
 
385
    def lock_tree_or_branch(wt, br):
 
386
        if wt is not None:
 
387
            wt.lock_read()
 
388
            add_cleanup(wt.unlock)
 
389
        elif br is not None:
 
390
            br.lock_read()
 
391
            add_cleanup(br.unlock)
 
392
 
342
393
    # Get the old location
343
394
    specific_files = []
344
395
    if old_url is None:
345
396
        old_url = default_location
346
397
    working_tree, branch, relpath = \
347
398
        bzrdir.BzrDir.open_containing_tree_or_branch(old_url)
 
399
    lock_tree_or_branch(working_tree, branch)
348
400
    if consider_relpath and relpath != '':
349
401
        if working_tree is not None and apply_view:
350
402
            views.check_path_in_view(working_tree, relpath)
358
410
    if new_url != old_url:
359
411
        working_tree, branch, relpath = \
360
412
            bzrdir.BzrDir.open_containing_tree_or_branch(new_url)
 
413
        lock_tree_or_branch(working_tree, branch)
361
414
        if consider_relpath and relpath != '':
362
415
            if working_tree is not None and apply_view:
363
416
                views.check_path_in_view(working_tree, relpath)
411
464
                    old_label='a/', new_label='b/',
412
465
                    extra_trees=None,
413
466
                    path_encoding='utf8',
414
 
                    using=None):
 
467
                    using=None,
 
468
                    format_cls=None):
415
469
    """Show in text form the changes from one tree to another.
416
470
 
417
 
    to_file
418
 
        The output stream.
419
 
 
420
 
    specific_files
421
 
        Include only changes to these files - None for all changes.
422
 
 
423
 
    external_diff_options
424
 
        If set, use an external GNU diff and pass these options.
425
 
 
426
 
    extra_trees
427
 
        If set, more Trees to use for looking up file ids
428
 
 
429
 
    path_encoding
430
 
        If set, the path will be encoded as specified, otherwise is supposed
431
 
        to be utf8
 
471
    :param to_file: The output stream.
 
472
    :param specific_files:Include only changes to these files - None for all
 
473
        changes.
 
474
    :param external_diff_options: If set, use an external GNU diff and pass 
 
475
        these options.
 
476
    :param extra_trees: If set, more Trees to use for looking up file ids
 
477
    :param path_encoding: If set, the path will be encoded as specified, 
 
478
        otherwise is supposed to be utf8
 
479
    :param format_cls: Formatter class (DiffTree subclass)
432
480
    """
 
481
    if format_cls is None:
 
482
        format_cls = DiffTree
433
483
    old_tree.lock_read()
434
484
    try:
435
485
        if extra_trees is not None:
437
487
                tree.lock_read()
438
488
        new_tree.lock_read()
439
489
        try:
440
 
            differ = DiffTree.from_trees_options(old_tree, new_tree, to_file,
441
 
                                                 path_encoding,
442
 
                                                 external_diff_options,
443
 
                                                 old_label, new_label, using)
 
490
            differ = format_cls.from_trees_options(old_tree, new_tree, to_file,
 
491
                                                   path_encoding,
 
492
                                                   external_diff_options,
 
493
                                                   old_label, new_label, using)
444
494
            return differ.show_diff(specific_files, extra_trees)
445
495
        finally:
446
496
            new_tree.unlock()
748
798
                target.close()
749
799
        finally:
750
800
            source.close()
 
801
        try:
 
802
            mtime = tree.get_file_mtime(file_id)
 
803
        except errors.FileTimestampUnavailable:
 
804
            pass
 
805
        else:
 
806
            os.utime(full_path, (mtime, mtime))
751
807
        if not allow_write:
752
808
            osutils.make_readonly(full_path)
753
 
        try:
754
 
            mtime = tree.get_file_mtime(file_id)
755
 
        except errors.FileTimestampUnavailable:
756
 
            mtime = 0
757
 
        os.utime(full_path, (mtime, mtime))
758
809
        return full_path
759
810
 
760
811
    def _prepare_files(self, file_id, old_path, new_path, force_temp=False,
882
933
    def show_diff(self, specific_files, extra_trees=None):
883
934
        """Write tree diff to self.to_file
884
935
 
885
 
        :param sepecific_files: the specific files to compare (recursive)
 
936
        :param specific_files: the specific files to compare (recursive)
886
937
        :param extra_trees: extra trees to use for mapping paths to file_ids
887
938
        """
888
939
        try:
978
1029
            if error_path is None:
979
1030
                error_path = old_path
980
1031
            raise errors.NoDiffFound(error_path)
 
1032
 
 
1033
 
 
1034
format_registry = Registry()
 
1035
format_registry.register('default', DiffTree)