This file is indexed.

/usr/share/psychtoolbox-3/PsychOneliners/RemoveMatchingPaths.m is in psychtoolbox-3-common 3.0.14.20170103+git6-g605ff5c.dfsg1-1build1.

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
function newPathList = RemoveMatchingPaths(pathList, matchString)
% newPathList = RemoveMatchingPaths(pathList, matchString)
%
% Removes any paths that contain the given matchString from the pathList.
% If no pathList is specified, then the program sets pathList to the result
% of the 'path' command.  This function returns a 'pathsep' delimited list
% of paths, omitting the paths that contained the given matchString.

% History:
% 30.05.13 Adapted from RemoveSVNPaths, to remove arbitrary paths (BSH)
% 31.05.13 Allow empty string for pathList to get current path.
%          Remove filesep prepended to match string, so that what this does
%          matches the comment.

% If no pathList was passed to the function we'll just grab the one from
% Matlab.
if (nargin < 1 || isempty(pathList))
    % Grab the path list.
    pathList = path;
end

% if no matchString was provided, return the path unmodified
if nargin < 2
    newPathList = pathList;
    return;
end

try
    % We do the matching path removal in a try-catch block, because some of
    % the functions used inside this block are not available in Matlab-5
    % and GNU/Octave. Our catch - block provides fail-safe behaviour for
    % that case.
    
    % Break the path list into individual path elements.
    if IsOctave
        pathElements = strsplit(pathList,pathsep,true);
    else
        pathElements = textscan(pathList, '%s', 'delimiter', pathsep);
        pathElements = pathElements{1}.';
    end
    
    % Look at each element from the path.  If it doesn't contain a matching
    % folder then we add it to the end of our new path list.
    isNotMatching = cellfun(@isempty,strfind(pathElements,matchString));
    pathElements = pathElements(isNotMatching);
    
    if ~isempty(pathElements)
        % generate new pathList
        pathElements = [pathElements; repmat({pathsep},1,length(pathElements))];
        newPathList  = [pathElements{:}];
        
        % drop last separator
        newPathList(end) = [];
    end
catch
    % Fallback behaviour: We fail-safe by simply returning the unmodified
    % pathList. No .svn paths removed, but the whole beast is still
    % functional.
    newPathList = pathList;
end