# HG changeset patch # User Martin von Zweigbergk # Date 1608230623 28800 # Node ID dadca47e3d4de022973b09ae691f4ac773b91f0a # Parent 634cea2c247f1b111cb655c42a07783e1ec06772 errors: respect ui.detailed-exit-code in chg This fixes `test-globalopts.t`, which has been failing since db5dddb38f5b (errors: raise InputError on early parse error in dispatch, 2020-11-23). Differential Revision: https://phab.mercurial-scm.org/D9630 diff -r 634cea2c247f -r dadca47e3d4d mercurial/chgserver.py --- a/mercurial/chgserver.py Thu Dec 17 13:33:27 2020 -0500 +++ b/mercurial/chgserver.py Thu Dec 17 10:43:43 2020 -0800 @@ -505,6 +505,7 @@ """ args = self._readlist() errorraised = False + detailed_exit_code = 255 try: self.ui, lui = _loadnewui(self.ui, args, self.cdebug) except error.RepoError as inst: @@ -515,12 +516,17 @@ self.ui.error(_(b"(%s)\n") % inst.hint) errorraised = True except error.Abort as inst: + if isinstance(inst, error.InputError): + detailed_exit_code = 10 self.ui.error(inst.format()) errorraised = True if errorraised: self.ui.flush() - self.cresult.write(b'exit 255') + exit_code = 255 + if self.ui.configbool(b'ui', b'detailed-exit-code'): + exit_code = detailed_exit_code + self.cresult.write(b'exit %d' % exit_code) return newhash = hashstate.fromui(lui, self.hashstate.mtimepaths) insts = []