This file is indexed.

/usr/share/psychtoolbox-3/PsychHardware/PR670Toolbox/PR670init.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
function retval = PR670init(portNumber)
% PR670init - Initialize the serial port to talk to the PR-670.
%
% Syntax:
% retval = PR670init
% retval = PR670init(portNumber)
%
% Description:
% Initializes the serial port for talking to colorimeter. Returns whatever
% character is sent by colorimeter
%
% Input:
% portNumber (1xN char) - Name of the serial port to use.
%
% Output:
% retval (1xN char) - Character data returned from the PR-670.

global g_serialPort;

if nargin == 0
    % This seems to be the default name on OS X. We don't know about other
    % operating systems defaults:
    portNumber = FindSerialPort('usbmodem', 1);
end

% Only open if we haven't already.
if isempty(g_serialPort)
    % IOPort has above port settings 9600 baud, no parity, 8 data bits,
    % 1 stopbit, no handshake (aka FlowControl=none) already as
    % built-in defaults, so no need to pass them:
    oldverbo = IOPort('Verbosity', 2);
    g_serialPort = IOPort('OpenSerialPort', portNumber, 'Lenient DontFlushOnWrite=1');
    IOPort('Verbosity', oldverbo);
end

% Tell the PR-670 to exit remote mode.  We do this to ensure a response from
% the device when we go into remote mode.  I've found it only responds the
% first time it's asked to go into remote mode.  There is no return code
% for this command.
PR670write('Q', 0);
pause(0.5);

% Put in remote mode.
PR670write('PHOTO', 0);

% Get the response.  Timeout after 10 seconds.
StartTime = GetSecs;
retval = [];
while isempty(retval) && (GetSecs-StartTime) < 10
    retval = PR670read;
end