/
mtree_rIndex_fcn.m
74 lines (45 loc) · 1.82 KB
/
mtree_rIndex_fcn.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
function index = mtree_rIndex_fcn(mtreeobj, fcn_name, index)
cIndex = mtree_cIndex();
rIndex_mtreeobj = mtree_rIndex(mtreeobj);
if ~isstruct(fcn_name)
if iscell(fcn_name)
name = fcn_name;
fcn_name = struct();
l = size(name,2);
for i = 1:l
fcn_name.(name{1,i}) = name{1,i};
end
else
name = fcn_name;
fcn_name = struct();
fcn_name.(name) = name;
end
end
stringTableIndex = mtreeobj.T(:, cIndex.stringTableIndex);
field_names = fieldnames(fcn_name);
for i = 1:length(fields(fcn_name))
name = field_names{i};
index1 = strcmp(mtreeobj.C, fcn_name.(name));
cIndex_allFcn = find(index1);
index2 = ismember(stringTableIndex, cIndex_allFcn);
index2 = find(index2)';
index2 = index2(index2 ~= rIndex_mtreeobj.HEAD.Fname);
if isempty(index2)
continue
end
% find all functions calls ofq preprocessed i-th function in rhs
index.(name).Fname = index2;
% get Call node
index.(name).Call = mtreeobj.T(index.(name).Fname, cIndex.indexParentNode)';
index.(name) = mtree_rIndex_getFunctionArguments(mtreeobj, index.(name), 'Call');
% get expr node
index.(name).Expr = mtree_findNode(mtreeobj, index.(name).Call, mtreeobj.K.EXPR);
% get equals node
index.(name).Equals = mtreeobj.T(index.(name).Expr, cIndex.indexLeftchild)';
index.(name).LineBeforeFcnCall_Expr = mtreeobj.T(index.(name).Expr, cIndex.indexParentNode);
index.(name).LineBeforeFcnCall_Equals = mtreeobj.T(index.(name).LineBeforeFcnCall_Expr, cIndex.indexLeftchild);
if index.(name).LineBeforeFcnCall_Equals ~= 0
index.(name).LineBeforeFcnCall_Function_Index = mtreeobj.T(index.(name).LineBeforeFcnCall_Equals, cIndex.indexLeftchild);
end
end
end