1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
|
/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
#include <stdio.h>
#include <string.h>
#include "timecard.h"
#include "mozilla/mozalloc.h"
Timecard* create_timecard() {
Timecard* tc = moz_xcalloc(1, sizeof(Timecard));
tc->entries_allocated = TIMECARD_INITIAL_TABLE_SIZE;
tc->entries = moz_xcalloc(tc->entries_allocated, sizeof(TimecardEntry));
tc->start_time = PR_Now();
return tc;
}
void destroy_timecard(Timecard* tc) {
free(tc->entries);
free(tc);
}
void stamp_timecard(Timecard* tc, const char* event, const char* file,
unsigned int line, const char* function) {
TimecardEntry* entry = NULL;
/* Trim the path component from the filename */
const char* last_slash = file;
while (*file) {
if (*file == '/' || *file == '\\') {
last_slash = file;
}
file++;
}
file = last_slash;
if (*file == '/' || *file == '\\') {
file++;
}
/* Ensure there is enough space left in the entries list */
if (tc->curr_entry == tc->entries_allocated) {
tc->entries_allocated *= 2;
tc->entries = moz_xrealloc(tc->entries,
tc->entries_allocated * sizeof(TimecardEntry));
}
/* Record the data into the timecard entry */
entry = &tc->entries[tc->curr_entry];
entry->timestamp = PR_Now();
entry->event = event;
entry->file = file;
entry->line = line;
entry->function = function;
tc->curr_entry++;
}
void print_timecard(Timecard* tc) {
size_t i;
TimecardEntry* entry;
size_t event_width = 5;
size_t file_width = 4;
size_t function_width = 8;
size_t line_width;
PRTime offset, delta;
for (i = 0; i < tc->curr_entry; i++) {
entry = &tc->entries[i];
if (strlen(entry->event) > event_width) {
event_width = strlen(entry->event);
}
if (strlen(entry->file) > file_width) {
file_width = strlen(entry->file);
}
if (strlen(entry->function) > function_width) {
function_width = strlen(entry->function);
}
}
printf("\nTimecard created %4ld.%6.6ld\n\n",
(long)(tc->start_time / PR_USEC_PER_SEC),
(long)(tc->start_time % PR_USEC_PER_SEC));
line_width =
1 + 11 + 11 + event_width + file_width + 6 + function_width + (4 * 3);
printf(" %-11s | %-11s | %-*s | %-*s | %-*s\n", "Timestamp", "Delta",
(int)event_width, "Event", (int)file_width + 6, "File",
(int)function_width, "Function");
for (i = 0; i <= line_width; i++) {
printf("=");
}
printf("\n");
for (i = 0; i < tc->curr_entry; i++) {
entry = &tc->entries[i];
offset = entry->timestamp - tc->start_time;
if (i > 0) {
delta = entry->timestamp - tc->entries[i - 1].timestamp;
} else {
delta = entry->timestamp - tc->start_time;
}
printf(" %4ld.%6.6ld | %4ld.%6.6ld | %-*s | %*s:%-5d | %-*s\n",
(long)(offset / PR_USEC_PER_SEC), (long)(offset % PR_USEC_PER_SEC),
(long)(delta / PR_USEC_PER_SEC), (long)(delta % PR_USEC_PER_SEC),
(int)event_width, entry->event, (int)file_width, entry->file,
entry->line, (int)function_width, entry->function);
}
printf("\n");
}
|