This repository has been archived by the owner on Feb 20, 2018. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathafclean.m
155 lines (128 loc) · 3.62 KB
/
afclean.m
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
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
function fh_clean=afclean(fh)
%AFCLEAN - Tries to purge an anonymous function of all non-essential workspace data
%
% fh_clean=afclean(fh)
%
%in:
%
% fh: an anonymous funtion
%
%out:
%
% fh_clean: The same as fh, but with its workspace reduced to the
% essential variables.
%
% DISCLAIMERS: The cleaning process will break anonymous functions that call nested
% functions or subfunctions. Unfortunately also, the implementation of AFCLEAN relies
% on a certain amount of undocumented MATLAB, in particular the FUNCTIONS command whose
% behavior in future releases of MATLAB, The MathWorks doesn't guarantee. It also
% makes heavy use of EVAL. When the tool works, it seems to work well, but use at your
% own risk!
%
% Copyright (c) 2015, Matt J
% 2-clause ("Simplified") BSD license
s=functions(fh);
s=s.workspace{1};
eval(structvars(s).');
clear s
fstr=func2str(fh);
fh_clean=eval(fstr);
clear fstr fh
function assigns=structvars(varargin)
%STRUCTVARS - print a set of assignment commands that, if executed, would
%assign fields of a structure to individual variables of the same name (or vice
%versa).
%
%Examples: Given structure myStruct, with fields a,b,c, & d
%
% (1) structvars(myStruct) %assign fields to variables
%
% ans =
%
% a = myStruct.a;
% b = myStruct.b;
% c = myStruct.c;
% d = myStruct.d;
%
% (2) structvars(3,myStruct) %split the last result across 3 columns
%
% ans =
%
% a = myStruct.a; c = myStruct.c; d = myStruct.d;
% b = myStruct.b;
%
% (3) structvars(3,myStruct,0) %assign variables to fields
%
% ans =
%
% myStruct.a = a; myStruct.c = c; myStruct.d = d;
% myStruct.b = b;
%
%The routine is useful when you want to pass many arguments to a function
%by packing them in a structure. The commands produced by structvars(...)
%can be conveniently copy/pasted into the file editor at the location in the file
%where the variables need to be unpacked.
%
%
%SYNTAX I:
%
% assigns=structvars(InputStructure,RHS)
%
% in:
% InputStructure: A structure
% RHS: Boolean. If true (default), dot indexing expressions will be on the
% right hand side.
%
% out:
%
% assigns: a text string containing the commands (see Examples above)
%
%
%
% NOTE: If the name of the variable passed as InputStructure cannot be
% determined via inputname() a default name of 'S' will be used.
%
%
%SYNTAX II:
%
% assigns=structvars(nCols,...)
%
%Same as syntax I, but assignment strings will be split across nCols
%columns.
%
%
% by Matt Jacobson
%
% Copyright, Xoran Technologies, Inc. 2009
%
if isnumeric(varargin{1}),
nCols=varargin{1};
varargin(1)=[];
idx=2;
else
nCols=1;
idx=1;
end
nn=length(varargin);
S=varargin{1};
if nn<2, RHS=true; else RHS=varargin{2}; end
fields=fieldnames(S);
sname=inputname(idx);
if isempty(sname), sname='S'; end
if RHS
assigns= cellfun(@(f) [f ' = ' sname '.' f '; '],fields,'uniformoutput',0);
else %LHS
assigns= cellfun(@(f) [ sname '.' f ' = ' f '; '],fields,'uniformoutput',0);
end
L0=length(assigns);
L=ceil(L0/nCols)*nCols;
Template=false(nCols,L/nCols);
Template(1:L0)=true;
Template=Template.';
Table=cell(size(Template));
Table(:)={' '};
Table(Template)=assigns;
for ii=1:nCols,
TextCols{ii}=strvcat(Table(:,ii));
end
assigns=[TextCols{:}];