summaryrefslogtreecommitdiffstats
path: root/libeshprof/hooks.esh
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