/b-gtk/fix-viz

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/b-gtk/fix-viz

« back to all changes in this revision

Viewing changes to revisionview.py

Merge trunk.

Show diffs side-by-side

added added

removed removed

Lines of Context:
22
22
import gobject
23
23
import webbrowser
24
24
 
 
25
from bzrlib import trace
25
26
from bzrlib.osutils import format_date
26
27
from bzrlib.util.bencode import bdecode
27
28
from bzrlib.testament import Testament
422
423
        self._add_parents_or_children(revision.parent_ids,
423
424
                                      self.parents_widgets,
424
425
                                      self.parents_table)
425
 
        
 
426
 
426
427
        file_info = revision.properties.get('file-info', None)
427
428
        if file_info is not None:
428
 
            file_info = bdecode(file_info.encode('UTF-8'))
 
429
            try:
 
430
                file_info = bdecode(file_info.encode('UTF-8'))
 
431
            except ValueError:
 
432
                trace.note('Invalid per-file info for revision:%s, value: %r',
 
433
                           revision.revision_id, file_info)
 
434
                file_info = None
429
435
 
430
436
        if file_info:
431
437
            if self._file_id is None:
509
515
        table.resize(max(len(revids), 1), 2)
510
516
 
511
517
        for idx, revid in enumerate(revids):
512
 
            align = gtk.Alignment(0.0, 0.0)
 
518
            align = gtk.Alignment(0.0, 0.0, 1, 1)
513
519
            widgets.append(align)
514
520
            table.attach(align, 1, 2, idx, idx + 1,
515
521
                                      gtk.EXPAND | gtk.FILL, gtk.FILL)
532
538
                hbox.pack_start(button, expand=False, fill=True)
533
539
                button.show()
534
540
 
535
 
            button = gtk.Button(revid)
 
541
            button = gtk.Button()
 
542
            revid_label = gtk.Label(str(revid))
 
543
            revid_label.set_ellipsize(pango.ELLIPSIZE_MIDDLE)
 
544
            revid_label.set_alignment(0.0, 0.5)
 
545
            button.add(revid_label)
536
546
            button.connect("clicked",
537
547
                    lambda w, r: self.set_revision(self._repository.get_revision(r)), revid)
538
548
            button.set_use_underline(False)
539
 
            hbox.pack_start(button, expand=False, fill=True)
540
 
            button.show()
 
549
            hbox.pack_start(button, expand=True, fill=True)
 
550
            button.show_all()
541
551
 
542
552
    def _create_general(self):
543
553
        vbox = gtk.VBox(False, 6)
566
576
        self.table.set_col_spacings(6)
567
577
        self.table.show()
568
578
 
569
 
        align = gtk.Alignment(1.0, 0.5)
 
579
        row = 0
 
580
 
570
581
        label = gtk.Label()
 
582
        label.set_alignment(1.0, 0.5)
571
583
        label.set_markup("<b>Revision Id:</b>")
572
 
        align.add(label)
573
 
        self.table.attach(align, 0, 1, 0, 1, gtk.FILL, gtk.FILL)
574
 
        align.show()
 
584
        self.table.attach(label, 0, 1, row, row+1, gtk.FILL, gtk.FILL)
575
585
        label.show()
576
586
 
577
 
        align = gtk.Alignment(0.0, 0.5)
578
587
        revision_id = gtk.Label()
 
588
        revision_id.set_ellipsize(pango.ELLIPSIZE_MIDDLE)
 
589
        revision_id.set_alignment(0.0, 0.5)
579
590
        revision_id.set_selectable(True)
580
591
        self.connect('notify::revision', 
581
592
                lambda w, p: revision_id.set_text(self._revision.revision_id))
582
 
        align.add(revision_id)
583
 
        self.table.attach(align, 1, 2, 0, 1, gtk.EXPAND | gtk.FILL, gtk.FILL)
584
 
        align.show()
 
593
        self.table.attach(revision_id, 1, 2, row, row+1, gtk.EXPAND | gtk.FILL, gtk.FILL)
585
594
        revision_id.show()
586
595
 
587
 
        align = gtk.Alignment(1.0, 0.5)
 
596
        row += 1
588
597
        self.author_label = gtk.Label()
 
598
        self.author_label.set_alignment(1.0, 0.5)
589
599
        self.author_label.set_markup("<b>Author:</b>")
590
 
        align.add(self.author_label)
591
 
        self.table.attach(align, 0, 1, 1, 2, gtk.FILL, gtk.FILL)
592
 
        align.show()
 
600
        self.table.attach(self.author_label, 0, 1, row, row+1, gtk.FILL, gtk.FILL)
593
601
        self.author_label.show()
594
602
 
595
 
        align = gtk.Alignment(0.0, 0.5)
596
603
        self.author = gtk.Label()
 
604
        self.author.set_ellipsize(pango.ELLIPSIZE_END)
 
605
        self.author.set_alignment(0.0, 0.5)
597
606
        self.author.set_selectable(True)
598
 
        align.add(self.author)
599
 
        self.table.attach(align, 1, 2, 1, 2, gtk.EXPAND | gtk.FILL, gtk.FILL)
600
 
        align.show()
 
607
        self.table.attach(self.author, 1, 2, row, row+1, gtk.EXPAND | gtk.FILL, gtk.FILL)
601
608
        self.author.show()
602
609
        self.author.hide()
603
610
 
604
 
        align = gtk.Alignment(1.0, 0.5)
 
611
        row += 1
605
612
        label = gtk.Label()
 
613
        label.set_alignment(1.0, 0.5)
606
614
        label.set_markup("<b>Committer:</b>")
607
 
        align.add(label)
608
 
        self.table.attach(align, 0, 1, 2, 3, gtk.FILL, gtk.FILL)
609
 
        align.show()
 
615
        self.table.attach(label, 0, 1, row, row+1, gtk.FILL, gtk.FILL)
610
616
        label.show()
611
617
 
612
 
        align = gtk.Alignment(0.0, 0.5)
613
618
        self.committer = gtk.Label()
 
619
        self.committer.set_ellipsize(pango.ELLIPSIZE_END)
 
620
        self.committer.set_alignment(0.0, 0.5)
614
621
        self.committer.set_selectable(True)
615
 
        align.add(self.committer)
616
 
        self.table.attach(align, 1, 2, 2, 3, gtk.EXPAND | gtk.FILL, gtk.FILL)
617
 
        align.show()
 
622
        self.table.attach(self.committer, 1, 2, row, row+1, gtk.EXPAND | gtk.FILL, gtk.FILL)
618
623
        self.committer.show()
619
624
 
620
 
        align = gtk.Alignment(0.0, 0.5)
 
625
        row += 1
621
626
        label = gtk.Label()
 
627
        label.set_alignment(1.0, 0.5)
622
628
        label.set_markup("<b>Branch nick:</b>")
623
 
        align.add(label)
624
 
        self.table.attach(align, 0, 1, 3, 4, gtk.FILL, gtk.FILL)
 
629
        self.table.attach(label, 0, 1, row, row+1, gtk.FILL, gtk.FILL)
625
630
        label.show()
626
 
        align.show()
627
631
 
628
 
        align = gtk.Alignment(0.0, 0.5)
629
632
        self.branchnick_label = gtk.Label()
 
633
        self.branchnick_label.set_ellipsize(pango.ELLIPSIZE_MIDDLE)
 
634
        self.branchnick_label.set_alignment(0.0, 0.5)
630
635
        self.branchnick_label.set_selectable(True)
631
 
        align.add(self.branchnick_label)
632
 
        self.table.attach(align, 1, 2, 3, 4, gtk.EXPAND | gtk.FILL, gtk.FILL)
 
636
        self.table.attach(self.branchnick_label, 1, 2, row, row+1, gtk.EXPAND | gtk.FILL, gtk.FILL)
633
637
        self.branchnick_label.show()
634
 
        align.show()
635
638
 
636
 
        align = gtk.Alignment(1.0, 0.5)
 
639
        row += 1
637
640
        label = gtk.Label()
 
641
        label.set_alignment(1.0, 0.5)
638
642
        label.set_markup("<b>Timestamp:</b>")
639
 
        align.add(label)
640
 
        self.table.attach(align, 0, 1, 4, 5, gtk.FILL, gtk.FILL)
641
 
        align.show()
 
643
        self.table.attach(label, 0, 1, row, row+1, gtk.FILL, gtk.FILL)
642
644
        label.show()
643
645
 
644
 
        align = gtk.Alignment(0.0, 0.5)
645
646
        self.timestamp = gtk.Label()
 
647
        self.timestamp.set_ellipsize(pango.ELLIPSIZE_END)
 
648
        self.timestamp.set_alignment(0.0, 0.5)
646
649
        self.timestamp.set_selectable(True)
647
 
        align.add(self.timestamp)
648
 
        self.table.attach(align, 1, 2, 4, 5, gtk.EXPAND | gtk.FILL, gtk.FILL)
649
 
        align.show()
 
650
        self.table.attach(self.timestamp, 1, 2, row, row+1, gtk.EXPAND | gtk.FILL, gtk.FILL)
650
651
        self.timestamp.show()
651
652
 
652
 
        align = gtk.Alignment(1.0, 0.5)
 
653
        row += 1
653
654
        self.tags_label = gtk.Label()
 
655
        self.tags_label.set_alignment(1.0, 0.5)
654
656
        self.tags_label.set_markup("<b>Tags:</b>")
655
 
        align.add(self.tags_label)
656
 
        align.show()
657
 
        self.table.attach(align, 0, 1, 5, 6, gtk.FILL, gtk.FILL)
 
657
        self.table.attach(self.tags_label, 0, 1, row, row+1, gtk.FILL, gtk.FILL)
658
658
        self.tags_label.show()
659
659
 
660
 
        align = gtk.Alignment(0.0, 0.5)
661
660
        self.tags_list = gtk.Label()
662
 
        align.add(self.tags_list)
663
 
        self.table.attach(align, 1, 2, 5, 6, gtk.EXPAND | gtk.FILL, gtk.FILL)
664
 
        align.show()
 
661
        self.tags_list.set_ellipsize(pango.ELLIPSIZE_MIDDLE)
 
662
        self.tags_list.set_alignment(0.0, 0.5)
 
663
        self.table.attach(self.tags_list, 1, 2, row, row+1, gtk.EXPAND | gtk.FILL, gtk.FILL)
665
664
        self.tags_list.show()
666
665
 
667
666
        self.connect('notify::revision', self._add_tags)