Show More
@@ -38,6 +38,7 b' import os' | |||
|
38 | 38 | |
|
39 | 39 | from mercurial import ( |
|
40 | 40 | pycompat, |
|
41 | util, | |
|
41 | 42 | ) |
|
42 | 43 | from mercurial.utils import ( |
|
43 | 44 | procutil, |
@@ -49,27 +50,50 b' from mercurial.utils import (' | |||
|
49 | 50 | # leave the attribute unspecified. |
|
50 | 51 | testedwith = 'ships-with-hg-core' |
|
51 | 52 | |
|
53 | class processlogger(object): | |
|
54 | """Map log events to external commands | |
|
55 | ||
|
56 | Arguments are passed on as environment variables. | |
|
57 | """ | |
|
58 | ||
|
59 | def __init__(self, ui): | |
|
60 | self._scripts = dict(ui.configitems(b'logtoprocess')) | |
|
61 | ||
|
62 | def tracked(self, event): | |
|
63 | return bool(self._scripts.get(event)) | |
|
64 | ||
|
65 | def log(self, ui, event, msg, opts): | |
|
66 | script = self._scripts.get(event) | |
|
67 | if not script: | |
|
68 | return | |
|
69 | env = { | |
|
70 | b'EVENT': event, | |
|
71 | b'HGPID': os.getpid(), | |
|
72 | b'MSG1': msg[0] % msg[1:], | |
|
73 | } | |
|
74 | # keyword arguments get prefixed with OPT_ and uppercased | |
|
75 | env.update((b'OPT_%s' % key.upper(), value) | |
|
76 | for key, value in pycompat.byteskwargs(opts).items()) | |
|
77 | fullenv = procutil.shellenviron(env) | |
|
78 | procutil.runbgcommand(script, fullenv, shell=True) | |
|
79 | ||
|
52 | 80 | def uisetup(ui): |
|
53 | 81 | |
|
54 | 82 | class logtoprocessui(ui.__class__): |
|
55 | def log(self, event, *msg, **opts): | |
|
56 | """Map log events to external commands | |
|
57 | ||
|
58 | Arguments are passed on as environment variables. | |
|
83 | def __init__(self, src=None): | |
|
84 | super(logtoprocessui, self).__init__(src) | |
|
85 | if src and r'_ltplogger' in src.__dict__: | |
|
86 | self._ltplogger = src._ltplogger | |
|
59 | 87 | |
|
60 | """ | |
|
61 | script = self.config('logtoprocess', event) | |
|
62 | if script: | |
|
63 | env = { | |
|
64 | b'EVENT': event, | |
|
65 | b'HGPID': os.getpid(), | |
|
66 | b'MSG1': msg[0] % msg[1:], | |
|
67 | } | |
|
68 | # keyword arguments get prefixed with OPT_ and uppercased | |
|
69 | env.update((b'OPT_%s' % key.upper(), value) | |
|
70 | for key, value in pycompat.byteskwargs(opts).items()) | |
|
71 | fullenv = procutil.shellenviron(env) | |
|
72 | procutil.runbgcommand(script, fullenv, shell=True) | |
|
88 | # trick to initialize logger after configuration is loaded, which | |
|
89 | # can be replaced later with processlogger(ui) in uisetup(), where | |
|
90 | # both user and repo configurations should be available. | |
|
91 | @util.propertycache | |
|
92 | def _ltplogger(self): | |
|
93 | return processlogger(self) | |
|
94 | ||
|
95 | def log(self, event, *msg, **opts): | |
|
96 | self._ltplogger.log(self, event, msg, opts) | |
|
73 | 97 | return super(logtoprocessui, self).log(event, *msg, **opts) |
|
74 | 98 | |
|
75 | 99 | # Replace the class for this instance and all clones created from it: |
General Comments 0
You need to be logged in to leave comments.
Login now