2011-12-10 15:46:07 -05:00
|
|
|
function [] = OPLogConvert(logfile)
|
2011-11-09 12:49:50 -06:00
|
|
|
%% Define indices and arrays of structures to hold data
|
|
|
|
% THIS FILE IS AUTOMATICALLY GENERATED.
|
2010-12-13 03:03:24 +00:00
|
|
|
$(ALLOCATIONCODE)
|
2011-11-09 12:49:50 -06:00
|
|
|
|
|
|
|
fid = fopen(logfile);
|
|
|
|
|
|
|
|
% Parse log file, entry by entry
|
|
|
|
while (1)
|
|
|
|
%% Read logging header
|
|
|
|
timestamp = fread(fid, 1, 'uint32');
|
|
|
|
if (feof(fid)); break; end
|
|
|
|
datasize = fread(fid, 1, 'int64');
|
|
|
|
|
|
|
|
|
|
|
|
%% Read message header
|
|
|
|
% get sync field (0x3C, 1 byte)
|
|
|
|
sync = fread(fid, 1, 'uint8');
|
|
|
|
if sync ~= hex2dec('3C')
|
|
|
|
disp ('Wrong sync byte');
|
|
|
|
return
|
|
|
|
end
|
|
|
|
% get msg type (quint8 1 byte ) should be 0x20, ignore the rest?
|
|
|
|
msgType = fread(fid, 1, 'uint8');
|
|
|
|
if msgType ~= hex2dec('20')
|
|
|
|
disp ('Wrong msgType');
|
|
|
|
return
|
|
|
|
end
|
|
|
|
% get msg size (quint16 2 bytes) excludes crc, include msg header and data payload
|
|
|
|
msgSize = fread(fid, 1, 'uint16');
|
|
|
|
% get obj id (quint32 4 bytes)
|
|
|
|
objID = fread(fid, 1, 'uint32');
|
|
|
|
|
|
|
|
|
|
|
|
%% Read object
|
|
|
|
switch objID
|
|
|
|
$(SWITCHCODE)
|
|
|
|
otherwise
|
|
|
|
disp(['Unknown object ID: 0x' dec2hex(objID)]);
|
|
|
|
msgBytesLeft = datasize - 1 - 1 - 2 - 4;
|
|
|
|
fread(fid, msgBytesLeft, 'uint8');
|
|
|
|
end
|
|
|
|
|
2010-12-13 03:03:24 +00:00
|
|
|
end
|
|
|
|
|
2011-11-09 12:49:50 -06:00
|
|
|
%% Clean Up and Save mat file
|
|
|
|
fclose(fid);
|
|
|
|
|
|
|
|
matfile = strrep(logfile,'opl','mat');
|
|
|
|
save(matfile $(SAVEOBJECTSCODE));
|
|
|
|
|
|
|
|
|
|
|
|
|
2010-12-13 03:03:24 +00:00
|
|
|
|
|
|
|
%% Object reading functions
|
|
|
|
$(FUNCTIONSCODE)
|
|
|
|
|
|
|
|
|