annotate sched/timed_action.m @ 2:7357e1dc2ad6
Simplified scheduler library with new schedule representation.
author |
samer |
date |
Sat, 22 Dec 2012 16:17:51 +0000 |
parents |
672052bd81f8 |
children |
0ce3c2070089 |
rev |
line source |
samer@2
|
1 % timed_action - return action function that checks the time
|
samer@2
|
2 %
|
samer@2
|
3 % timed_action ::
|
samer@2
|
4 % (A1, A2, ... => B1, B2, ...) ~'some action',
|
samer@2
|
5 % -> timed_action({A1,A2,...},{B1,B2,...}).
|
samer@2
|
6 function a0=timed_action(x,varargin)
|
samer@2
|
7 opts=prefs('print',0,'errorfn',@(t)nows-t,varargin{:});
|
samer@2
|
8 if opts.print, a0=@aa_print; else a0=@aa; end
|
samer@2
|
9 errfn=opts.errorfn;
|
samer@0
|
10
|
samer@2
|
11 function varargout=aa_print(t0,varargin),
|
samer@2
|
12 varargout{1}=errfn(t0);
|
samer@2
|
13 [varargout{2:nargout}]=x(varargin{:});
|
samer@2
|
14 fprintf('timed_action: error=%g\n',varargout{1});
|
samer@2
|
15 end
|
samer@2
|
16 function varargout=aa(t0,varargin),
|
samer@2
|
17 varargout{1}=errfn(t0);
|
samer@2
|
18 [varargout{2:nargout}]=x(varargin{:});
|
samer@0
|
19 end
|
samer@0
|
20 end
|