blob: f5bc76d41cd9991dfb2b5ef4ffbbafcd7632e61b [file] [log] [blame]
Mike Frysingerf6013762019-06-13 02:30:51 -04001# -*- coding:utf-8 -*-
Shawn O. Pearcead3193a2009-04-18 09:54:51 -07002#
3# Copyright (C) 2008 The Android Open Source Project
4#
5# Licensed under the Apache License, Version 2.0 (the "License");
6# you may not use this file except in compliance with the License.
7# You may obtain a copy of the License at
8#
9# http://www.apache.org/licenses/LICENSE-2.0
10#
11# Unless required by applicable law or agreed to in writing, software
12# distributed under the License is distributed on an "AS IS" BASIS,
13# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14# See the License for the specific language governing permissions and
15# limitations under the License.
16
Mike Frysinger8a11f6f2019-08-27 00:26:15 -040017"""Logic for tracing repo interactions.
18
19Activated via `repo --trace ...` or `REPO_TRACE=1 repo ...`.
20"""
21
Sarah Owenscecd1d82012-11-01 22:59:27 -070022from __future__ import print_function
Shawn O. Pearcead3193a2009-04-18 09:54:51 -070023import sys
24import os
Mike Frysinger8a11f6f2019-08-27 00:26:15 -040025
26# Env var to implicitly turn on tracing.
Shawn O. Pearcead3193a2009-04-18 09:54:51 -070027REPO_TRACE = 'REPO_TRACE'
28
Mike Frysinger8a11f6f2019-08-27 00:26:15 -040029_TRACE = os.environ.get(REPO_TRACE) == '1'
Shawn O. Pearcead3193a2009-04-18 09:54:51 -070030
31def IsTrace():
32 return _TRACE
33
34def SetTrace():
35 global _TRACE
36 _TRACE = True
37
38def Trace(fmt, *args):
39 if IsTrace():
Sarah Owenscecd1d82012-11-01 22:59:27 -070040 print(fmt % args, file=sys.stderr)