This file is indexed.

/usr/share/psychtoolbox-3/PsychHardware/BitsPlusToolbox/BitsPlusSetClut.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
function BitsPlusSetClut(windowPtr, clutOrTexturePtr, rect, doFlip)
%  BitsPlusSetClut(windowPtr, clutOrTexturePtr, [rect], [doFlip])
% 
% Prior to using this routine, Bits++ box must be in
% framebuffer load mode.
%
% 'clutOrTexturePtr' will either be a 256x3 matrix in the range [0,2^16-1]
% or it will be a texture generated by BitsPlusPlusClut2Texture.
%
% 'rect' lets you define the rect that specifies where the magic code is
% written.  For a typical application, this should be left empty.  However,
% for programs that modify the projection matrix via MOGL, you will want to
% change this to draw the magic code in a more cosmetically appealing
% location.
%
% If 'doFlip' is set to 1, then BitsPlusSetClut will call flip at the
% end of the function.  By default, this value is 1.

% 2/28/03   dhb, ptw  Wrote it.
% 18/4/05   ejw converted it to run with OSX version of Psychtoolbox

if nargin < 2 || nargin > 4
    error('Usage: BitsPlusSetClut(windowPtr, clut, [rect], [doFlip])');
end

switch nargin
    case 2
        rect = [];
        doFlip = true;
    case 3
        doFlip = true;
end

% Make sure that 'rect' has valid dimensions.
if ~isempty(rect) && (size(rect, 1) ~= 1 || size(rect, 2) ~= 4)
    error('rect must be a 4 element vector.');
end

% Decide if we've been passed a texture pointer or a clut matrix.
isTexture = isscalar(clutOrTexturePtr);

if ~isTexture
    % Encode the LUT.
    newClutRow = BitsPlusEncodeClutRow(clutOrTexturePtr);
end

% Find out how big the window is.
[screenWidth, screenHeight] = Screen('WindowSize', windowPtr);

% check that the screen width is at least 524 pixels
if screenWidth < 524
    error('Window is not big enough to encode the Bits++ CLUT.');
end 

if isempty(rect)
    if isTexture
        rect = [0, 0, 524, 1];
    else
        rect = [0, 0, size(newClutRow, 2), 1];
    end
end

if isTexture
    Screen('DrawTexture', windowPtr, clutOrTexturePtr, [0 0 524 1], rect, 0, 0);
else
    % Scale the clut to match the color range.
    colorRange = Screen('ColorRange', windowPtr);
    newClutRow = newClutRow ./ 255 .* colorRange;

    Screen('PutImage', windowPtr, newClutRow, rect);
end

if doFlip
    Screen(windowPtr, 'Flip');
end