blob: ff9b5eeb76fd6312813b1e598ed77263ce4d51cd [file] [log] [blame]
niklase@google.com470e71d2011-07-07 08:21:25 +00001/*
2 * Copyright (c) 2011 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
11#include "TimedTrace.h"
12#include <math.h>
13
14double TimedTrace::_timeEllapsedSec = 0;
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +000015FILE* TimedTrace::_timedTraceFile = NULL;
niklase@google.com470e71d2011-07-07 08:21:25 +000016
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +000017TimedTrace::TimedTrace() {
niklase@google.com470e71d2011-07-07 08:21:25 +000018
19}
20
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +000021TimedTrace::~TimedTrace() {
22 if (_timedTraceFile != NULL) {
23 fclose(_timedTraceFile);
24 }
25 _timedTraceFile = NULL;
niklase@google.com470e71d2011-07-07 08:21:25 +000026}
27
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +000028int16_t TimedTrace::SetUp(char* fileName) {
29 if (_timedTraceFile == NULL) {
30 _timedTraceFile = fopen(fileName, "w");
31 }
32 if (_timedTraceFile == NULL) {
33 return -1;
34 }
35 return 0;
niklase@google.com470e71d2011-07-07 08:21:25 +000036}
37
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +000038void TimedTrace::SetTimeEllapsed(double timeEllapsedSec) {
39 _timeEllapsedSec = timeEllapsedSec;
niklase@google.com470e71d2011-07-07 08:21:25 +000040}
41
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +000042double TimedTrace::TimeEllapsed() {
43 return _timeEllapsedSec;
niklase@google.com470e71d2011-07-07 08:21:25 +000044}
45
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +000046void TimedTrace::Tick10Msec() {
47 _timeEllapsedSec += 0.010;
niklase@google.com470e71d2011-07-07 08:21:25 +000048}
49
tina.legrand@webrtc.orgd5726a12013-05-03 07:34:12 +000050void TimedTrace::TimedLogg(char* message) {
51 unsigned int minutes = (uint32_t) floor(_timeEllapsedSec / 60.0);
52 double seconds = _timeEllapsedSec - minutes * 60;
53 //char myFormat[100] = "%8.2f, %3u:%05.2f: %s\n";
54 if (_timedTraceFile != NULL) {
55 fprintf(_timedTraceFile, "%8.2f, %3u:%05.2f: %s\n", _timeEllapsedSec,
56 minutes, seconds, message);
57 }
niklase@google.com470e71d2011-07-07 08:21:25 +000058}