blob: a17ec77ed425792d4135d1ee36c03dd4701974e8 (
plain)
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
|
# Eggshell profiling library
#
# Copyright (C) 2016 Patrick "P. J." McDermott
#
# This file is part of the Eggshell Linker.
#
# The Eggshell Linker is free software: you can redistribute it
# and/or modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation, either version 3 of
# the License, or (at your option) any later version.
#
# The Eggshell Linker is distributed in the hope that it will be
# useful, but WITHOUT ANY WARRANTY; without even the implied warranty
# of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with the Eggshell Linker If not, see
# <http://www.gnu.org/licenses/>.
__prof_stack_sz=0
__prof_fn_begin()
{
if [ ${__prof_stack_sz} -eq 0 ]; then
exec 9>eshmon.out
fi
printf '%s %s %s\n' "$(date '+%s.%N')" 'B' "${1}" >&9
__prof_stack_sz=$((${__prof_stack_sz} + 1))
}
__fn_begin_hook __prof_fn_begin
__prof_fn_end()
{
printf '%s %s %s\n' "$(date '+%s.%N')" 'E' "${1}" >&9
__prof_stack_sz=$((${__prof_stack_sz} - 1))
if [ ${__prof_stack_sz} -eq 0 ]; then
exec 9>&-
fi
}
__fn_end_hook __prof_fn_end
|