This file is indexed.

/usr/share/psychtoolbox-3/PsychHardware/PR650Toolbox/PR650measspd.m is in psychtoolbox-3-common 3.0.12.20160126.dfsg1-1ubuntu1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

 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
function [spd, qual] = PR650measspd(S,syncMode)
% [spd,qual] = PR650measspd(S,[syncMode])
%
% Make a measurement of the spectrum.  Tries to be smart
% about using sync or not, unless it is turned off by
% passed variable.
%
% syncMode = 'on':  Try to sync integration time with display.  Retry without if it fails. (default)
% syncMode = 'off': Don't try to sync.
% 
% 8/26/10  dhb  Add DEBUG option to figure out why this dies sometimes.
% 3/8/11   dhb  Pass syncMode option to speed things up for displays where it doesn't work.

DEBUG = 1;

global g_serialPort;

% Handle defaults
if nargin < 2 || isempty(syncMode)
    syncMode = 'on';
end

% Check for initialization
if isempty(g_serialPort)
   error('Meter has not been initialized.');
end

% Set wavelength sampling if passed.
if nargin < 1 || isempty(S)
   S = [380 5 81];
end

% Initialize
timeout = 30;

% See if we can sync to the source and set sync mode appropriately.
if (strcmp(syncMode,'on'))
    syncFreq = PR650getsyncfreq;
    if ~isempty(syncFreq)
        PR650setsyncfreq(1);
    else
        PR650setsyncfreq(0);
    end
else
    PR650setsyncfreq(0);
end

% Do raw read
readStr = PR650rawspd(timeout);

% fprintf('Got data\n');
qual = sscanf(readStr,'%f',1);
	 
% Check for sync mode error condition.  If get one,
% turn off sync and try again.
if qual == 7 || qual == 8
    if (DEBUG)
        fprintf('Got qual code of %d, setting sync freq to 0 and trying again.\n',qual);
    end
	PR650setsyncfreq(0);
	readStr = PR650rawspd(timeout);
	qual = sscanf(readStr, '%f', 1);
    if (DEBUG)
        fprintf('Retry returns quality code of %d\n',qual);
    end
end
	
% Check for other error conditions
if qual == -1 || qual == 10
  %disp('Low light level during measurement');
  %disp('Setting returned value to zero');
  spd = zeros(S(3), 1);
elseif qual == 18 || qual == 0
	spd = PR650parsespdstr(readStr, S);	
elseif qual ~= 0
  error('Bad return code %g from meter', qual);
end