# HG changeset patch # User Yuya Nishihara # Date 1541907194 -32400 # Node ID b2e5a554bc7b2a794bb5d0d4f7863eb642df0b16 # Parent fbac323eb6250395674653868f3e325feb2a53e4 logtoprocess: rewrite dict building in py3-compatible way diff -r fbac323eb625 -r b2e5a554bc7b hgext/logtoprocess.py --- a/hgext/logtoprocess.py Sun Nov 11 12:27:23 2018 +0900 +++ b/hgext/logtoprocess.py Sun Nov 11 12:33:14 2018 +0900 @@ -34,9 +34,11 @@ from __future__ import absolute_import -import itertools import os +from mercurial import ( + pycompat, +) from mercurial.utils import ( procutil, ) @@ -70,17 +72,16 @@ messages = (formatted,) + msg[1:] else: messages = msg + env = { + b'EVENT': event, + b'HGPID': os.getpid(), + } # positional arguments are listed as MSG[N] keys in the # environment - msgpairs = ( - ('MSG{0:d}'.format(i), m) - for i, m in enumerate(messages, 1)) + env.update((b'MSG%d' % i, m) for i, m in enumerate(messages, 1)) # keyword arguments get prefixed with OPT_ and uppercased - optpairs = ( - ('OPT_{0}'.format(key.upper()), value) - for key, value in opts.iteritems()) - env = dict(itertools.chain(msgpairs, optpairs), - EVENT=event, HGPID=os.getpid()) + env.update((b'OPT_%s' % key.upper(), value) + for key, value in pycompat.byteskwargs(opts).items()) fullenv = procutil.shellenviron(env) procutil.runbgcommand(script, fullenv, shell=True) return super(logtoprocessui, self).log(event, *msg, **opts)