-
Notifications
You must be signed in to change notification settings - Fork 16
/
Copy pathmff_importinfo.m
84 lines (71 loc) · 3.08 KB
/
mff_importinfo.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
% mff_importinfo - import information from MFF 'info.xml' file
%
% Usage:
% info = mff_exportsignal(mffFile);
%
% Inputs:
% mffFile - filename/foldername for the MFF file
%
% Output:
% info - Matlab structure containing informations contained in the MFF
% file.
% This file is part of mffmatlabio.
%
% mffmatlabio 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.
%
% mffmatlabio 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 mffmatlabio. If not, see <https://www.gnu.org/licenses/>.
function [infoMatlab, beginTime] = mff_importinfo(mffFile)
mff_path;
mfffactorydelegate = javaObject('com.egi.services.mff.api.LocalMFFFactoryDelegate');
mfffactory = javaObject('com.egi.services.mff.api.MFFFactory', mfffactorydelegate);
infotype = javaObject('com.egi.services.mff.api.MFFResourceType', javaMethod('valueOf', 'com.egi.services.mff.api.MFFResourceType$MFFResourceTypes', 'kMFF_RT_Info'));
info = mfffactory.openResourceAtURI( fullfile(mffFile, 'info.xml'), infotype);
infoMatlab.version = 0;
infoMatlab.timezone = [];
infoMatlab.recordtimematlab = 0;
if ~isempty(info)
%try
if (info.loadResource() == true)
% The files version number.
if (info.getMFFVersionPresent() == true)
fprintf( 'MFF Version: %d\n', info.getMFFVersion());
infoMatlab.version = info.getMFFVersion(); % Integer
end
% The recording time.
timeVal = char(info.getRecordTime());
fprintf( 'File''s Recording Time: %s\n', timeVal);
infoMatlab.recordtime = timeVal;
% get the time zone (duplicate code in mff_importevents and mff_importinfo)
minusSign = find(timeVal == '+');
if isempty(minusSign)
minusSign = find(timeVal == '-');
minusSign = minusSign(end);
end
timeZone = timeVal(minusSign(end):end);
if length(timeZone) > 6
timeZone = [];
disp('Issue with decoding the time zone');
end
infoMatlab.timezone = timeZone;
% decode time
beginTime = mff_decodetime(timeVal); % with millisec resolution
infoMatlab.recordtimematlab = mff_decodetime(timeVal); % string
else
fprintf( 'Error: Could not load Info resource; file might be corrupted.\n');
end
%catch
% error( 'Unknown while decoding info ressource; send us your data file.\n');
%end
else
error( 'Error: Could not open the Info resource; check path\n');
end
mfffactory.closeResource(info);