Kiln » TortoiseHg » TortoiseHg
Clone URL:  
Pushed to one repository · View In Graph Contained in 1.9, 1.9.1, and 1.9.2

sync: add details dialog for --force, --newbranch, etc

Not real happy with the details dialog layout; but it's functional

Changeset 82ca67c8c4d2

Parent 5a590fa8a136

by Steve Borho

Changes to one file · Browse files at 82ca67c8c4d2 Showing diff from parent 5a590fa8a136 Diff from another changeset...

 
47
48
49
 
50
51
52
 
196
197
198
199
200
201
202
203
204
205
206
207
208
 
249
250
251
252
253
254
255
 
 
 
256
257
258
 
416
417
418
419
 
420
421
 
 
 
 
 
 
 
 
 
 
422
423
424
 
474
475
476
477
 
 
478
479
480
 
490
491
492
493
 
494
495
496
 
505
506
507
508
509
 
 
 
510
511
512
 
 
513
514
515
 
548
549
550
551
 
552
553
554
 
557
558
559
560
 
 
561
562
563
 
972
973
974
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
975
976
977
 
47
48
49
50
51
52
53
 
197
198
199
 
 
 
 
 
 
 
200
201
202
 
243
244
245
 
 
 
 
246
247
248
249
250
251
 
409
410
411
 
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
 
477
478
479
 
480
481
482
483
484
 
494
495
496
 
497
498
499
500
 
509
510
511
 
 
512
513
514
515
516
 
517
518
519
520
521
 
554
555
556
 
557
558
559
560
 
563
564
565
 
566
567
568
569
570
 
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
1026
1027
1028
1029
1030
1031
1032
1033
1034
1035
1036
1037
1038
1039
1040
1041
1042
1043
1044
1045
1046
1047
1048
1049
1050
1051
1052
1053
1054
1055
1056
1057
1058
1059
1060
1061
1062
1063
1064
1065
1066
1067
1068
@@ -47,6 +47,7 @@
  self.curuser = None   self.curpw = None   self.updateInProgress = False + self.opts = {}     self.repo.configChanged.connect(self.configChanged)   @@ -196,13 +197,6 @@
  self.outbutton, self.pushbutton,   self.emailbutton, self.p4pbutton)   - self.forcepush = False - self.newbranch = False - self.forcepull = False - self.torev = None - self.tobranch = None - self.remotecmd = None -   cmd = cmdui.Widget(not embedded, self)   cmd.commandStarted.connect(self.commandStarted)   cmd.commandFinished.connect(self.commandFinished) @@ -249,10 +243,9 @@
  self.reload()     def details(self): - pass - #dlg = DetailsDialog(self.opts, self.userhist, self) - #if dlg.exec_() == QDialog.Accepted: - # self.opts.update(dlg.outopts) + dlg = DetailsDialog(self.opts, self) + if dlg.exec_() == QDialog.Accepted: + self.opts.update(dlg.outopts)     def reload(self):   # Refresh configured paths @@ -416,9 +409,19 @@
  if dialog.exec_() == QDialog.Accepted:   self.curuser, self.curpw = '', ''   - def run(self, cmdline): + def run(self, cmdline, details):   if self.cmd.core.is_running():   return + for name in list(details) + ['remotecmd']: + val = self.opts.get(name) + if not val: + continue + if isinstance(val, bool): + if val: + cmdline.append('--' + name) + elif val: + cmdline.append('--' + name) + cmdline.append(val)   url = self.currentUrl(False)   safeurl = self.currentUrl(True)   display = ' '.join(cmdline + [safeurl]) @@ -474,7 +477,8 @@
  else:   self.showMessage.emit(_('Incoming aborted, ret %d') % ret)   self.finishfunc = finished - self.run(['--repository', self.root, 'incoming']) + cmdline = ['--repository', self.root, 'incoming'] + self.run(cmdline, ('force', 'branch', 'rev'))     def pullclicked(self):   def finished(ret, output): @@ -490,7 +494,7 @@
  cmdline.append('--update')   elif self.cachedpp == 'fetch':   cmdline[2] = 'fetch' - self.run(cmdline) + self.run(cmdline, ('force', 'branch', 'rev'))     def outclicked(self):   if self.embedded: @@ -505,11 +509,13 @@
  else:   self.showMessage.emit(_('Outgoing aborted, ret %d') % ret)   self.finishfunc = outputnodes - self.run(['--repository', self.root, 'outgoing', - '--quiet', '--template', '{node}\n']) + cmdline = ['--repository', self.root, 'outgoing', '--quiet', + '--template', '{node}\n'] + self.run(cmdline, ('force', 'new-branch', 'branch', 'rev'))   else:   self.finishfunc = None - self.run(['--repository', self.root, 'outgoing']) + cmdline = ['--repository', self.root, 'outgoing'] + self.run(cmdline, ('force', 'new-branch', 'branch', 'rev'))     def p4pending(self):   def finished(ret, output): @@ -548,7 +554,7 @@
  dlg = PerforcePending(self.repo, pending, self)   dlg.exec_()   self.finishfunc = finished - self.run(['--repository', self.root, 'p4pending', '--verbose']) + self.run(['--repository', self.root, 'p4pending', '--verbose'], ())     def pushclicked(self):   def finished(ret, output): @@ -557,7 +563,8 @@
  else:   self.showMessage.emit(_('Push aborted, ret %d') % ret)   self.finishfunc = finished - self.run(['--repository', self.root, 'push', '--verbose']) + cmdline = ['--repository', self.root, 'push'] + self.run(cmdline, ('force', 'new-branch', 'branch', 'rev'))     def postpullclicked(self):   dlg = PostPullDialog(self.repo, self) @@ -972,6 +979,90 @@
  return fn, wconfig.readfile(fn)     +class DetailsDialog(QDialog): + 'Utility dialog for configuring uncommon settings' + def __init__(self, opts, parent): + QDialog.__init__(self, parent) + self.repo = parent.repo + + layout = QFormLayout() + self.setLayout(layout) + + self.newbranchcb = QCheckBox(_('Allow push of a new branch')) + self.newbranchcb.setChecked(opts.get('new-branch', False)) + layout.addRow(self.newbranchcb, None) + self.forcecb = QCheckBox(_('Force pull or push (override checks)')) + self.forcecb.setChecked(opts.get('force', False)) + layout.addRow(self.forcecb, None) + + self.branchcb = QCheckBox(_('Specify branch for push/pull:')) + self.branchle = QLineEdit() + self.branchle.setEnabled(False) + self.branchcb.toggled.connect(self.branchle.setEnabled) + if opts.get('branch'): + self.branchcb.setChecked(True) + self.branchle.setText(hglib.tounicode(opts['branch'])) + else: + self.branchcb.setChecked(False) + self.branchcb.clicked.emit(True) + layout.addRow(self.branchcb, self.branchle) + + self.revcb = QCheckBox(_('Specify revision for push/pull:')) + self.revle = QLineEdit() + self.revle.setEnabled(False) + self.revcb.toggled.connect(self.revle.setEnabled) + if opts.get('rev'): + self.revcb.setChecked(True) + self.revle.setText(hglib.tounicode(opts['rev'])) + else: + self.revcb.setChecked(False) + self.revcb.clicked.emit(True) + layout.addRow(self.revcb, self.revle) + + self.remotecb = QCheckBox(_('Remote command:')) + self.remotele = QLineEdit() + self.remotele.setEnabled(False) + self.remotecb.toggled.connect(self.remotele.setEnabled) + if opts.get('remotecmd'): + self.remotecb.setChecked(True) + self.remotele.setText(hglib.tounicode(opts['remotecmd'])) + else: + self.remotecb.setChecked(False) + self.remotecb.clicked.emit(True) + layout.addRow(self.remotecb, self.remotele) + + BB = QDialogButtonBox + bb = QDialogButtonBox(BB.Ok|BB.Cancel) + bb.accepted.connect(self.accept) + bb.rejected.connect(self.reject) + self.bb = bb + layout.addWidget(bb) + + self.setWindowTitle('%s - sync details' % self.repo.displayname) + + def accept(self): + outopts = {} + + for name, cb, le in (('branch', self.branchcb, self.branchle), + ('rev', self.revcb, self.revle), + ('remotecmd', self.remotecb, self.remotele)): + if cb.isChecked(): + outopts[name] = hglib.fromunicode(self.branchle.text()) + else: + outopts[name] = '' + + if outopts.get('branch') and outopts.get('rev'): + qtlib.WarningMsgBox(_('Configuration Error'), + _('You cannot specify a branch and revision'), + parent=self) + return + + outopts['force'] = self.forcecb.isChecked() + outopts['new-branch'] = self.newbranchcb.isChecked() + + self.outopts = outopts + QDialog.accept(self) +    def run(ui, *pats, **opts):   from tortoisehg.util import paths