/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
|