# Copyright (C) 2020 The Android Open Source Project # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. """Event logging in the git trace2 EVENT format.""" from git_command import GetEventTargetPath from git_command import RepoSourceVersion from git_trace2_event_log_base import BaseEventLog class EventLog(BaseEventLog): """Event log that records events that occurred during a repo invocation. Events are written to the log as a consecutive JSON entries, one per line. Entries follow the git trace2 EVENT format. Each entry contains the following common keys: - event: The event name - sid: session-id - Unique string to allow process instance to be identified. - thread: The thread name. - time: is the UTC time of the event. Valid 'event' names and event specific fields are documented here: https://git-scm.com/docs/api-trace2#_event_format """ def __init__(self, **kwargs): super().__init__(repo_source_version=RepoSourceVersion(), **kwargs) def Write(self, path=None, **kwargs): if path is None: path = self._GetEventTargetPath() return super().Write(path=path, **kwargs) def _GetEventTargetPath(self): return GetEventTargetPath()