1
Fork 0
mirror of https://git.savannah.gnu.org/git/guile.git synced 2025-05-20 03:30:27 +02:00
Conflicts:
	module/statprof.scm
This commit is contained in:
Andy Wingo 2015-01-22 14:37:18 +01:00
commit 6f248df1f6
3 changed files with 28 additions and 12 deletions

View file

@ -1,6 +1,6 @@
@c -*-texinfo-*-
@c This is part of the GNU Guile Reference Manual.
@c Copyright (C) 2013 Free Software Foundation, Inc.
@c Copyright (C) 2013, 2015 Free Software Foundation, Inc.
@c See the file guile.texi for copying conditions.
@node Statprof
@ -220,7 +220,7 @@ The return value is a list of nodes, each of which is of the type:
@end defun
@anchor{statprof statprof}@defun statprof thunk [#:loop] [#:hz] [#:count-calls?] [#:full-stacks?]
Profiles the execution of @var{thunk}.
Profile the execution of @var{thunk}, and return its return values.
The stack will be sampled @var{hz} times per second, and the thunk
itself will be called @var{loop} times.
@ -236,7 +236,8 @@ retrieve the last-stored stacks.
@end defun
@anchor{statprof with-statprof}@defspec with-statprof args
Profiles the expressions in its body.
Profile the expressions in the body, and return the body's return
value.
Keyword arguments:

View file

@ -1,7 +1,7 @@
;;;; (statprof) -- a statistical profiler for Guile
;;;; -*-scheme-*-
;;;;
;;;; Copyright (C) 2009, 2010, 2011, 2013, 2014 Free Software Foundation, Inc.
;;;; Copyright (C) 2009, 2010, 2011, 2013-2015 Free Software Foundation, Inc.
;;;; Copyright (C) 2004, 2009 Andy Wingo <wingo at pobox dot com>
;;;; Copyright (C) 2001 Rob Browning <rlb at defaultvalue dot org>
;;;;
@ -829,15 +829,16 @@ The return value is a list of nodes, each of which is of the type:
equal?))))
(define (call-thunk thunk)
(thunk)
(values))
(call-with-values (lambda () (thunk))
(lambda results
(apply values results))))
(define* (statprof thunk #:key (loop 1) (hz 100) (count-calls? #f)
(port (current-output-port)) full-stacks?)
"Profiles the execution of @var{thunk}.
"Profile the execution of @var{thunk}, and return its return values.
The stack will be sampled @var{hz} times per second, and the thunk itself will
be called @var{loop} times.
The stack will be sampled @var{hz} times per second, and the thunk
itself will be called @var{loop} times.
If @var{count-calls?} is true, all procedure calls will be recorded. This
operation is somewhat expensive."
@ -853,15 +854,16 @@ operation is somewhat expensive."
(statprof-start state))
(lambda ()
(let lp ((i loop))
(unless (zero? i)
(unless (= i 1)
(call-thunk thunk)
(lp (1- i)))))
(lp (1- i))))
(call-thunk thunk))
(lambda ()
(statprof-stop state)
(statprof-display port state))))))
(define-macro (with-statprof . args)
"Profiles the expressions in its body.
"Profile the expressions in the body, and return the body's return values.
Keyword arguments:

View file

@ -45,6 +45,19 @@
(throw 'unresolved)
(apply throw args))))))
(pass-if-equal "return values"
'(42 77)
(call-with-values
(lambda ()
(with-output-to-port (%make-void-port "w")
(lambda ()
(with-statprof
(let loop ((i 10000))
(if (zero? i)
(values 42 77)
(loop (1- i))))))))
list))
(pass-if "statistical sample counts within expected range"
(when-implemented
;; test to see that if we call 3 identical functions equally, they