blob: cd571f4c83c4eb34e5539a916b011e8dfb23d771 [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
David Pursehouse819827a2020-02-12 15:20:19 +090031
Shawn O. Pearcead3193a2009-04-18 09:54:51 -070032def IsTrace():
33 return _TRACE
34
David Pursehouse819827a2020-02-12 15:20:19 +090035
Shawn O. Pearcead3193a2009-04-18 09:54:51 -070036def SetTrace():
37 global _TRACE
38 _TRACE = True
39
David Pursehouse819827a2020-02-12 15:20:19 +090040
Shawn O. Pearcead3193a2009-04-18 09:54:51 -070041def Trace(fmt, *args):
42 if IsTrace():
Sarah Owenscecd1d82012-11-01 22:59:27 -070043 print(fmt % args, file=sys.stderr)